前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Dijkstra

Dijkstra

作者头像
用户1154259
发布2018-01-17 18:43:30
5410
发布2018-01-17 18:43:30
举报

迪杰斯特拉算法是典型的求解最短路径的方法。

优点,时间复杂度为O(n2),主要思想就是遍历邻居,找到路径最短的邻居,添加到路径信息里面。再更新这个添加点,是否能减少到其他点的路径长度。

但是有一个缺点,就是这个算法只满足一个节点的扫描信息,如果想计算所有的节点到达其他节点的最短路径,就需要每次调用一次该算法。时间复杂度变为O(n3).

总体来说,分为两部分

第一部分:查找当前节点周围的最近的邻居;

代码语言:javascript
复制
min = INF;
        for(j=0;    j<MAXSIZE;  j++){
            if( !Final[j] && shotpathtable[j]<min){
                k = j;
                min = shotpathtable[j];
            }
        }

第二部分:超找通过这个最近的邻居,能否更快的到达其他的点。

代码语言:javascript
复制
for(j=0;    j<MAXSIZE;  j++){
            if( !Final[j] && (min + num[k][j]<shotpathtable[j])){
                shotpathtable[j] = min + num[k][j];
                path[j] = j;
            }
        }

全部代码展示

代码语言:javascript
复制
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #define MAXSIZE 9
 4 #define INF 65535
 5 int num[MAXSIZE][MAXSIZE] = {
 6     0,    1,  5,INF,INF,INF,INF,INF,INF,
 7     1,    0,  3,  7,  5,INF,INF,INF,INF,
 8     5,    3,  0,INF,  1,  7,INF,INF,INF,
 9     INF,  7,INF,  0,  2,INF,  3,INF,INF,
10     INF,  5,  1,  2,  0,  3,  6,  9,INF,
11     INF,INF,  7,INF,  3,  0,INF,  5,INF,
12     INF,INF,INF,  3,  6,INF,  0,  2,  7,
13     INF,INF,INF,INF,  9,  5,  2,  0,  4,
14     INF,INF,INF,INF,INF,INF,  7,  4,  0
15 };
16 int main()
17 {
18     int path[MAXSIZE];
19     int shotpathtable[MAXSIZE];
20 
21     int v0 = 0;
22 
23     int i,j,v,w,k,min;
24     int Final[MAXSIZE];
25     for(i=0;    i<MAXSIZE;  i++){
26         Final[i] = 0;
27         shotpathtable[i] = num[v0][i];
28         path[i] = 0;
29     }
30     shotpathtable[v0] = 0;
31     Final[v0] = 1;
32     printf("v0");
33     for(i=1;    i<MAXSIZE;  i++){
34         min = INF;
35         for(j=0;    j<MAXSIZE;  j++){
36             if( !Final[j] && shotpathtable[j]<min){
37                 k = j;
38                 min = shotpathtable[j];
39             }
40         }
41         Final[k] = 1;
42         printf("->%d",k);
43         for(j=0;    j<MAXSIZE;  j++){
44             if( !Final[j] && (min + num[k][j]<shotpathtable[j])){
45                 shotpathtable[j] = min + num[k][j];
46                 path[j] = j;
47             }
48         }
49     }
50     printf("\n");
51     printf("D:");
52     for(i=0;    i<MAXSIZE;  i++){
53         printf("%d ",shotpathtable[i]);
54     }
55     printf("\nPath:");
56     for(i=0;    i<MAXSIZE;  i++){
57         printf("%d ",path[i]);
58     }
59     return 0;
60 }

运行结果

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014-03-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第一部分:查找当前节点周围的最近的邻居;
  • 第二部分:超找通过这个最近的邻居,能否更快的到达其他的点。
  • 全部代码展示
  • 运行结果
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档