这是2010年GIS实习时写的一个小程序,Baidu空间显示编辑时间为2010-04-20 ,为了把技术与非技术博客区分,转到这里。
请查看2012年更新之后的文章版本2012年Dijkstra最短路径
//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]);
}