Dijkstra算法图文详解

本文转载自:https://blog.csdn.net/lbperfect123/article/details/84281300

Dijkstra算法

 

Dijkstra算法算是贪心思想实现的,首先把起点到所有点的距离存下来找个最短的,然后松弛一次再找出最短的,所谓的松弛操作就是,遍历一遍看通过刚刚找到的距离最短的点作为中转站会不会更近,如果更近了就更新距离,这样把所有的点找遍之后就存下了起点到其他所有点的最短距离。

 

问题引入:

指定一个点(源点)到其余各个顶点的最短路径,也叫做“单源最短路径”。例如求下图中的1号顶点到2、3、4、5、6号顶点的最短路径。

 

 

 

 

 

 下面我们来模拟一下:

 这就是Dijkstra算法的基本思路:

接下来是代码:

已经把几个过程都封装成了基本模块:


 
 
  1. #include<cstdio>
  2. #include<cstring>
  3. #include<algorithm>
  4. #include<iostream>
  5. #define Inf 0x3f3f3f3f
  6. using namespace std;
  7. int map[ 1005][ 1005];
  8. int vis[ 1005],dis[ 1005];
  9. int n,m; //n个点,m条边
  10. void Init ()
  11. {
  12. memset( map,Inf, sizeof( map));
  13. for( int i= 1;i<=n;i++)
  14. {
  15. map[i][i]= 0;
  16. }
  17. }
  18. void Getmap()
  19. {
  20. int u,v,w;
  21. for( int t= 1;t<=m;t++)
  22. {
  23. scanf( "%d%d%d",&u,&v,&w);
  24. if( map[u][v]>w)
  25. {
  26. map[u][v]=w;
  27. map[v][u]=w;
  28. }
  29. }
  30. }
  31. void Dijkstra(int u)
  32. {
  33. memset(vis, 0, sizeof(vis));
  34. for( int t= 1;t<=n;t++)
  35. {
  36. dis[t]= map[u][t];
  37. }
  38. vis[u]= 1;
  39. for( int t= 1;t<n;t++)
  40. {
  41. int minn=Inf,temp;
  42. for( int i= 1;i<=n;i++)
  43. {
  44. if(!vis[i]&&dis[i]<minn)
  45. {
  46. minn=dis[i];
  47. temp=i;
  48. }
  49. }
  50. vis[temp]= 1;
  51. for( int i= 1;i<=n;i++)
  52. {
  53. if( map[temp][i]+dis[temp]<dis[i])
  54. {
  55. dis[i]= map[temp][i]+dis[temp];
  56. }
  57. }
  58. }
  59. }
  60. int main()
  61. {
  62. scanf( "%d%d",&m,&n);
  63. Init();
  64. Getmap();
  65. Dijkstra(n);
  66. printf( "%d\n",dis[ 1]);
  67. return 0;
  68. }

 

 

  •                     <li class="tool-item tool-active is-like "><a href="javascript:;"><svg class="icon" aria-hidden="true">
                            <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#csdnc-thumbsup"></use>
                        </svg><span class="name">点赞</span>
                        <span class="count">51</span>
                        </a></li>
                        <li class="tool-item tool-active is-collection "><a href="javascript:;" data-report-click="{&quot;mod&quot;:&quot;popu_824&quot;}"><svg class="icon" aria-hidden="true">
                            <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#icon-csdnc-Collection-G"></use>
                        </svg><span class="name">收藏</span></a></li>
                        <li class="tool-item tool-active is-share"><a href="javascript:;"><svg class="icon" aria-hidden="true">
                            <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#icon-csdnc-fenxiang"></use>
                        </svg>分享</a></li>
                        <!--打赏开始-->
                                                <!--打赏结束-->
                                                <li class="tool-item tool-more">
                            <a>
                            <svg t="1575545411852" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5717" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M179.176 499.222m-113.245 0a113.245 113.245 0 1 0 226.49 0 113.245 113.245 0 1 0-226.49 0Z" p-id="5718"></path><path d="M509.684 499.222m-113.245 0a113.245 113.245 0 1 0 226.49 0 113.245 113.245 0 1 0-226.49 0Z" p-id="5719"></path><path d="M846.175 499.222m-113.245 0a113.245 113.245 0 1 0 226.49 0 113.245 113.245 0 1 0-226.49 0Z" p-id="5720"></path></svg>
                            </a>
                            <ul class="more-box">
                                <li class="item"><a class="article-report">文章举报</a></li>
                            </ul>
                        </li>
                                            </ul>
                </div>
                            </div>
            <div class="person-messagebox">
                <div class="left-message"><a href="https://blog.csdn.net/lbperfect123">
                    <img src="https://profile.csdnimg.cn/6/D/A/3_lbperfect123" class="avatar_pic" username="lbperfect123">
                                            <img src="https://g.csdnimg.cn/static/user-reg-year/2x/2.png" class="user-years">
                                    </a></div>
                <div class="middle-message">
                                        <div class="title"><span class="tit"><a href="https://blog.csdn.net/lbperfect123" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;}" target="_blank">lbperfect123</a></span>
                                            </div>
                    <div class="text"><span>发布了327 篇原创文章</span> · <span>获赞 354</span> · <span>访问量 10万+</span></div>
                </div>
                                <div class="right-message">
                                            <a href="https://im.csdn.net/im/main.html?userName=lbperfect123" target="_blank" class="btn btn-sm btn-red-hollow bt-button personal-letter">私信
                        </a>
                                                            <a class="btn btn-sm  bt-button personal-watch" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;}">关注</a>
                                    </div>
                            </div>
                    </div>
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值