Dijkstra 最短路径

这是2010年GIS实习时写的一个小程序,Baidu空间显示编辑时间为2010-04-20 ,为了把技术与非技术博客区分,转到这里。

//Dijkstra 最短路径
#include "stdio.h"
#include "math.h"

main()
{
int n,i,j;
int Cost[100][100];
int temp=999,count=999;
int Dist[100];
int Flag[100]={0};
int tag=999,CountJ;
int c;
/*测试用例
int Cost[6][6]={{999,999,10,999,30,100},{999,999,5,999,999,999},{999,999,999,50,999,999},{999,999,999,999,999,10},{999,999,999,20,999,60},{999,999,999,999,999,999}};
*n=6;
count=0;*/

printf("请输入结点个数n");//结点个数n,从1-n
scanf("%d",&n);

for(i=0;i<n;i++)//输入数据
for(j=0;j<n;j++)
{
loop:printf("请输入第%d到第%d个节点的距离,输入范围0-999之间的整数,不连通请输入999\n",i+1,j+1);

scanf("%d",&Cost[i][j]);
if(Cost[i][j]>=999||Cost[i][j]<0)
{
printf("输入错误,请输入0-999之间的数值");
goto loop;
}

if(temp==999&&Cost[i][j]<999&&Cost[i][j]>0)
{
temp=Cost[i][j];//i,j连通
count=i;//起始点序号count
}
}


for(i=0;i<n;i++)
Dist[i]=Cost[count][i];//各段距离


Flag[count]=1;// S终点标记为1


//Vj
for( c=0;c<n-1;c++)
{ tag=999;
for(i=0;i<n;i++)

if(Flag[i]==0&&tag>Dist[i])//Vi =V-S
{
tag=Dist[i];//Dist[j]=Min{Dist[i]|Vi=V-S
CountJ=i; //确定Vj
}
Flag[CountJ]=1;//标记

for(i=0;i<n;i++)
if(Flag[i]==0&&(Dist[CountJ]+Cost[CountJ][i])<Dist[i])
{
Dist[i]=Dist[CountJ]+Cost[CountJ][i];
// printf("到%d节点距离 %d=经%d节点为%d+%d\n",CountJ+1,Dist[CountJ],i+1,Dist[CountJ]+Cost[CountJ][i]);
}
}
for(i=0;i<n;i++)
if(Dist[i]!=999)
printf("从第%d个节点到第%d个节点最短路径为%d\n",count+1,i+1,Dist[i]);


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值