| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 804 人关注过本帖
标题:请指教“单源最短路径”问题
只看楼主 加入收藏
shanshangnu3
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2006-10-12
收藏
 问题点数:0 回复次数:0 
请指教“单源最短路径”问题

看一下我的程序怎么运行得不到正确的结果啊?次程序实现的功能是求单源最短路径,高手请帮忙~!~!~!感激感激
#define N 6 //顶点数
#define MAX 1000 //max是计算机允许的最大值
void main()
{int cost[N][N]; //cost为带权有向图的邻接矩阵
int v=0;
int a,b;
int dist[N],s[N],rear[N]; //dist[i]为当前源点到顶点i的最小距离,s表示相应顶点是否并入集合的标志;//到i顶点的最短路径存储在队列q[i]中,队头指针为0,队尾指针存储在节rear[i]中
int q[N][N];
int i,j,k,win,m;
for(a=0;a<=5;a++)
for(b=0;b<6;b++)
scanf("%d",&cost[a][b]);
for (i=1;i<N;i++) //初始化s和rear
{ s[i]=0;
rear[i]=-1;
}
for (i=1;i<N;i++) //初始化dist和q
{ dist[i]=cost[v][i];
if (dist[i]<MAX)
{ q[i][++rear[i]]=v;
q[i][++rear[i]]=i;
}
}
s[v]=1; //v并入集合
for (k=0;k<N-1;k++) //并入n-1个顶点,即求n-1条最短路径
{ win=MAX;j=v;
for (i=1;i<N;i++) //选最小的dist[j]
if (s[i]==0&&dist[i]<win)
{ j=i;win=dist[i];}
if (j!=i)
{ s[j]=1;
printf("\nthe %d's shortestdistance is %d\n",j,dist[j]);
for (i=0;i<=rear[j];i++)
printf("%5d",q[j][i]); //打印从源点到j的最短路径
for (i=1;i<N;i++)
if (s[i]==0&&((dist[j]+cost[j][i])<dist[i])) //现在从源点经过j到i比原来要短则修改
{ dist[i]=dist[j]+cost[j][i];
for (m=0;m<=rear[j];m++)
q[i][m]=q[j][m]; //修改相应的路径
rear[i]=rear[j];
q[i][++rear[i]]=i;
}
}
}
}

[此贴子已经被作者于2006-10-27 10:21:52编辑过]

搜索更多相关主题的帖子: 单源最短路径 指教 
2006-10-26 20:59
快速回复:请指教“单源最短路径”问题
数据加载中...
 
   



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

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