Dijkstra算法再学习

     最近在做一些题目,发现好多东西我都不会,顺便就把去年学的数据结构复习一点。

    Dijsktra这个算法我感觉是比较符合人类的思维方式的,从一个顶点到其他顶点的最短路径,稍微动一下脑筋就会知道,寻找最近的路径就是在经过所有可以到达目的地的最短。AB<ACB就是这样的。因此并不防设为ABCDEF要求从A点到达其他各点的最短路径。首先设置一个数组装从A直接到达的路径长度。

    void Dijkstra(int  n,int v,int dist[],int prev[],int c[][NUM])

   {

         int i,j;

         int s[NUM];                    

01111
     
     
     
     
 

         //初始化数组

        for(i=1;i<=n;i++)

       {

           dist[i]=c[v][i];//数组保存各个顶点到原点的直接距离

           s[i]=0;//s[i]=1表示到达原点的最短路径

           if(dist[i]>maxint)

           prev[i]=0;

           else  prev[i]=v;

      }

     //初始化源节点

     dist[v]=0;

     s[v]=1;

     for(i=1;i<n;i++)

     {

          int tmp=maxint;

          int u=v;

          for(j=1;j<=n;j++)

             if(!s[j]&&dist[j]<tmp)

             { 

                     u=j;

                     tmp=dist[j];

              }

         s[u]=1;//节点U加入S中

        for(j=1;j<=n;j++)

            if(!(s[i])&&c[u][j]<maxint)

        {        

               int newdist=dist[u]+c[u][j];

               if(newdist<dist[j])

               {

                       dist=newdist;

                       prev[j]=u;

                }

      }

 }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值