Dijkstra 最短路径

这是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]);

    


}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值