| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 838 人关注过本帖
标题:joj上一道关于prim算法的最小生成树问题,为什么我的程序总是wa
取消只看楼主 加入收藏
醉生梦死
Rank: 1
等 级:新手上路
帖 子:77
专家分:0
注 册:2007-8-21
收藏
 问题点数:0 回复次数:1 
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
等 级:新手上路
帖 子: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.016571 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved