说实在的,这算法很简单,很简单,很简单……因为它是贪心的,而且码量也小,常数比起SPFA也小。

主要思想

先初始化,dis[起点]=0,其它皆为无限大。

还要有一个bz数组,bz[i]表示i是否确定为最短路径

  1. for i=1 to n
  2. {
  3. 在未确定最短路径的点中找出u使dis[u]最小
  4. bz[u]=1;
  5. 更新与u相连的所有点
  6. }

就这么简单。

实现讲解

其实也很好实现。可以用邻接表储存,也可以用邻接矩阵储存,虽然会慢一点。因为Dijkstra算法本就是对付稠密图的,不过我还是建议用邻接表,见SPFA实现讲解

注意事项

Dijkstra不能处理负边权的状况,所以要看清题目大意才用它哦!

具体代码

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <string.h>
  4. #include <math.h>
  5. #include <limits.h>
  6. using namespace std;
  7. struct _Way//定义_Way类型,表示某点到点y的距离为len
  8. {
  9. int y,len;
  10. };
  11. int n,m;
  12. int q;
  13. _Way way[1001][1001] {};//way[i][j]表示从i开始的第j条路
  14. _Way* bz[1001][1001] {};//读入时标记,防止重边出现。bz[i][j]指向从i到j的直接路径
  15. int now[1001] {};//now[i]表示从i开始的边的数量
  16. int dis[1001] {};//dis[i]表示从起点到i的最短路径
  17. int min(int a,int b){return a<b?a:b;}
  18. void Dijkstra(int);
  19. int main()
  20. {
  21. ios::sync_with_stdio(false);
  22. cin>>n>>m;
  23. for(int i=1;i<=m;i++)
  24. {
  25. int x,y,len;
  26. cin>>x>>y>>len;
  27. if (bz[x][y]!=NULL)//若重边则替换之
  28. {
  29. bz[x][y]->len=min(bz[x][y]->len,len);
  30. continue;
  31. }
  32. now[x]++;
  33. way[x][now[x]].y=y;
  34. way[x][now[x]].len=len;
  35. bz[x][y]=&(way[x][now[x]]);//标记好地址
  36. }
  37. cin>>q;
  38. Dijkstra(q);
  39. for(int i=1;i<=n;i++)
  40. {
  41. if (dis[i]!=INT_MAX)
  42. cout<<dis[i]<<endl;
  43. else
  44. cout<<"-1"<<endl;
  45. }
  46. return 0;
  47. }
  48. void Dijkstra(int q)//注意Dijkstra算法不能有负边权
  49. {
  50. bool bz[1001] {};//bz[i]表示点i是否已标记成最短路径
  51. for(int i=0;i<=n;i++)
  52. dis[i]=INT_MAX;
  53. dis[q]=0;//初始化
  54. for(int i=1;i<=n;i++)
  55. {
  56. int u {};
  57. for(int j=1;j<=n;j++)
  58. if ((!bz[j])&&(dis[j]<dis[u]))
  59. u=j;//u为未确定点中dis最小的点
  60. if (u==0) break;
  61. bz[u]=1;//标记为确定点
  62. for(int i=1;i<=now[u];i++)
  63. dis[way[u][i].y]=min(dis[way[u][i].y],dis[u]+way[u][i].len);//更新与其相连的所有点
  64. }
  65. }

优化

用堆优化,暂时不会。

SPFA和Dijkstra哪个强?

SPFA擅长于稀疏图,而Dijkstra擅长于稠密图

SPFA可以处理负边权,Dijkstra不可以处理负边权

SPFA时间复杂度为O(kE),Dijkstra时间复杂度为O(n^2)

SPFA的空间要比Dijkstra多一个队列

SPFA的优化有SLF和LLL,Dijkstra的优化有堆优化

SPFA和Dijkstra均不可以处理负权回路

SPFA的时间系数要比Dijkstra大(Floyed和Ford笑了)

SPFA和Dijkstra都是单源的(Floyed又笑了)

没有边的图 O(1)特殊判断 SPFA秒过,完全图Dijkstra秒过(Floyed和Ford骄傲地说:“我们的时间是固定的!”)

图论最短路径算法——Dijkstra的更多相关文章

  1. 最短路径算法-Dijkstra算法的应用之单词转换(词梯问题)(转)

    一,问题描述 在英文单词表中,有一些单词非常相似,它们可以通过只变换一个字符而得到另一个单词.比如:hive-->five:wine-->line:line-->nine:nine- ...

  2. 有向有权图的最短路径算法--Dijkstra算法

    Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Di ...

  3. 最短路径算法Dijkstra和A*

    在设计基于地图的游戏,特别是isometric斜45度视角游戏时,几乎必须要用到最短路径算法.Dijkstra算法是寻找当前最优路径(距离原点最近),如果遇到更短的路径,则修改路径(边松弛). Ast ...

  4. 图论最短路径算法总结(Bellman-Ford + SPFA + DAGSP + Dijkstra + Floyd-Warshall)

    这里感谢百度文库,百度百科,维基百科,还有算法导论的作者以及他的小伙伴们...... 最短路是现实生活中很常见的一个问题,之前练习了很多BFS的题目,BFS可以暴力解决很多最短路的问题,但是他有一定的 ...

  5. 图论-最短路径 2.Dijkstra算法O (N2)

    2.Dijkstra算法O (N2) 用来计算从一个点到其他所有点的最短路径的算法,是一种单源最短路径算法.也就是说,只能计算起点只有一个的情况. Dijkstra的时间复杂度是O (N2),它不能处 ...

  6. 带权图的最短路径算法(Dijkstra)实现

    一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...

  7. 最短路径算法——Dijkstra,Bellman-Ford,Floyd-Warshall,Johnson

    根据DSqiu的blog整理出来 :http://dsqiu.iteye.com/blog/1689163 PS:模板是自己写的,如有错误欢迎指出~ 本文内容框架: §1 Dijkstra算法 §2 ...

  8. 最短路径算法——Dijkstra算法

    在路由选择算法中都要用到求最短路径算法.最出名的求最短路径算法有两个,即Bellman-Ford算法和Dijkstra算法.这两种算法的思路不同,但得出的结果是相同的. 下面只介绍Dijkstra算法 ...

  9. 最短路径算法——Dijkstra算法与Floyd算法

    转自:https://www.cnblogs.com/smile233/p/8303673.html 最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1    ADE:2  ...

随机推荐

  1. VS2010-MFC(Ribbon界面开发:使用更多控件并为控件添加消息处理函数)

    转自:http://www.jizhuomi.com/software/255.html 上一节讲了为Ribbon Bar添加控件的方法.本节教程将继续完善前面的实例,讲解一些稍复杂的控件的添加方法, ...

  2. 微信-小程序-开发文档-服务端-模板消息:templateMessage.getTemplateList

    ylbtech-微信-小程序-开发文档-服务端-模板消息:templateMessage.getTemplateList 1.返回顶部 1. templateMessage.getTemplateLi ...

  3. 解决jqGrid中,当前页一直显示为0的问题

    项目中,经常会见到使用 jqGrid 进行一些数据的列表展示,而且使用起来也比较方便.但是有时会遇到一些奇怪的问题,比如前几天我就遇到了在使用 jqGrid 时,当前页一直显示为 0 的问题.下图就是 ...

  4. Markdown文档常用字体及颜色设置

    1.字体.字号.颜色设置 <font face="微软雅黑" >微软雅黑字体</font> <font face="黑体" > ...

  5. java-day17

    软件结构:C/S客户端和服务器结构,B/S浏览器和服务器结构 网络通信协议 TCP:传输控制协议,面向连接的通信协议,即传输数据之前,发送端和接收端建立逻辑连接,然后再传输数据. 三次握手 UDP:用 ...

  6. uoj21 【UR #1】缩进优化

    题目 题意简介明了,需要找到一个\(T\),最小化 \[\sum_{i=1}^n\left \lfloor \frac{a_i}{T} \right \rfloor+\sum_{i=1}^na_i\% ...

  7. 控制音量大小widget

    由于手机音量按键非常悲剧的掉了.无法控制手机音量大小.使用起来非常不方便.所以决定写一个小widget放在桌面能够随时控制音量吧.也算是解决一点便利问题. 1.一个简单的widget 由于我的需求非常 ...

  8. ES6 学习 -- 字符串新增方法

    1.检测字符串中是否包含某个字符 ES5方法:string.indexOf("需要检测的字符"),如果返回值为-1,则说明当前字符串中不存在这个字符,返回值不为-1,则 是当前字符 ...

  9. java oop第07章_集合框架

    一. 什么是集合: 在Java中提供了一些可以保存同一数据类型的数据集称为集合,就是规定了一些集合的规范(接口.抽象类.实现类)及方法, 方便我们程序在保存数据时进行增.删.改.查操作,编程更加高效. ...

  10. jquery中on绑定click事件在苹果手机中不起作用

    写一个div当做了一个按钮来使用. <div class="button"> <div class="sure"> 确定 </di ...