| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 840 人关注过本帖
标题:joj上一道关于prim算法的最小生成树问题,为什么我的程序总是wa
只看楼主 加入收藏
醉生梦死
Rank: 1
等 级:新手上路
帖 子:77
专家分:0
注 册:2007-8-21
收藏
 问题点数:0 回复次数:4 
joj上一道关于prim算法的最小生成树问题,为什么我的程序总是wa

题目地址:

http://acm.jlu.edu.cn/joj/showproblem.php?pid=1170

我的程序:
#include <iostream>
using namespace std;

const int maxv = 9999;
int main()
{
int m; //m张地图
cin >> m;
while (m --)
{

int n; //记录有多少个顶点
cin >> n;
int c[n+1][n+1];
bool s[n+1];
int lowcost[n+1];
int minsum = 0;

for (int i = 1;i < n+1;i ++)
for (int j = 1;j < n+1;j ++)
c[i][j] = maxv;
//输入各个有连接顶点之间的边权
int b,e,d;
while (cin >> b && cin >>e && cin >>d && b != 0 && e !=0 && d != 0)
c[b][e] = d;

s[1] = true;

for (int i = 2;i <= n+1;i ++)
{
lowcost[i] = c[1][i];
s[i] = false;
}

for (int i = 1;i < n;i ++)
{
int j;
int min = maxv;
for (int k = 2;k < n+1;k ++)
if ((!s[k]) && (lowcost[k] < min))
{
min = lowcost[k];
j = k;
}
s[j] = true;

for (int k =2;k < n+1;k ++)
if ((c[j][k] < lowcost[k]) && (!s[k]))
lowcost[k] = c[j][k];
minsum += lowcost[j];
}
cout << minsum << endl;
}
}

请高手指教,在线等

搜索更多相关主题的帖子: 成树 joj prim 算法 小生 
2007-11-10 18:16
海子星竹
Rank: 1
等 级:新手上路
威 望:1
帖 子:58
专家分:0
注 册:2007-9-4
收藏
得分:0 
什么意思!!
2007-11-10 21:45
海子星竹
Rank: 1
等 级:新手上路
威 望:1
帖 子:58
专家分:0
注 册:2007-9-4
收藏
得分:0 
程序有很多语法错误哦!!
2007-11-10 21:46
crackerwang
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:833
专家分:0
注 册:2007-2-14
收藏
得分:0 
#include<stdio.h>
int a[100][100];
#define inf 1000000
int main()
{
int t,n,i,j,x;
int close[100];
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++) a[i][j]=inf;
close[i]=inf;
}
while(1)
{
scanf("%d%d%d",&i,&j,&x);
if(i==0&&j==0) break;
if(a[i][j]>x) a[i][j]=a[j][i]=x;
}
close[1]=0;
j=1;
int ans=0;
x=n;
while(x--)
{
ans+=close[j];
for(i=1;i<=n;i++)
{
if(close[i]!=-1&&close[i]>a[j][i])close[i]=a[j][i];
}
close[j]=-1;
for(j=1;close[j]==-1&&j<=n;j++);
for(i=j;i<=n;i++)
{
if(close[i]!=-1&&close[i]<close[j])j=i;
}
}
printf("%d\n",ans);
}
}

好象你没有处理重边

2007-11-10 23:50
醉生梦死
Rank: 1
等 级:新手上路
帖 子:77
专家分:0
注 册:2007-8-21
收藏
得分:0 
回复:(crackerwang)#includeint a[...

恩!谢了,考虑问题不严密,改为c[b][e] = c[e][b] = d;就ac了


2007-11-11 09:59
快速回复:joj上一道关于prim算法的最小生成树问题,为什么我的程序总是wa
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018420 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved