纯最短路。

  1. ///HDU 2544堆优化的最短路
  2. #include <cstdio>
  3. #include <iostream>
  4. #include <sstream>
  5. #include <cmath>
  6. #include <cstring>
  7. #include <cstdlib>
  8. #include <string>
  9. #include <vector>
  10. #include <map>
  11. #include <set>
  12. #include <queue>
  13. #include <stack>
  14. #include <algorithm>
  15. using namespace std;
  16. #define ll long long
  17. #define _cle(m, a) memset(m, a, sizeof(m))
  18. #define repu(i, a, b) for(int i = a; i < b; i++)
  19. #define repd(i, a, b) for(int i = b; i >= a; i--)
  20. #define sfi(n) scanf("%d", &n)
  21. #define pfi(n) printf("%d\n", n)
  22. const int MAXN = ;
  23. const int MAXM = ;
  24. const int INF=0x3f3f3f3f;
  25. struct Node
  26. {
  27. int to,next,w;
  28. } edge[MAXM];
  29. struct HeapNode
  30. {
  31. int d, u;
  32. bool operator < (const HeapNode& rhs) const
  33. {
  34. return d > rhs.d;
  35. }
  36. };
  37. struct Dijkstra
  38. {
  39. int head[MAXN],d[MAXN];
  40. bool done[MAXN];
  41. int cnt;
  42. void init()
  43. {
  44. memset(head,-,sizeof(head));
  45. cnt = ;
  46. }
  47. void AddEdge(int u, int v, int w)
  48. {
  49. edge[cnt].to=v,edge[cnt].next=head[u];
  50. edge[cnt].w=w,head[u]=cnt++;
  51. edge[cnt].to=u,edge[cnt].next=head[v];
  52. edge[cnt].w=w,head[v]=cnt++;
  53. }
  54. void dijkstra(int s,int n)
  55. {
  56. priority_queue<HeapNode> Q;
  57. for(int i = s; i <= n; i++)
  58. d[i] = INF;
  59. d[s] = ;
  60. memset(done, , sizeof(done));
  61. Q.push((HeapNode)
  62. {
  63. , s
  64. });
  65. while(!Q.empty())
  66. {
  67. HeapNode x = Q.top();
  68. Q.pop();
  69. int u = x.u;
  70. if(done[u]) continue;
  71. done[u] = true;
  72. for(int i=head[u]; i!=-; i=edge[i].next)
  73. {
  74. int v=edge[i].to;
  75. if(d[v] > d[u] + edge[i].w)
  76. {
  77. d[v] = d[u] + edge[i].w;
  78. Q.push((HeapNode)
  79. {
  80. d[v], v
  81. });
  82. }
  83. }
  84. }
  85. }
  86. } dij;
  87. int main()
  88. {
  89. int n,m,a,b,c;
  90. while(scanf("%d%d",&n,&m),n+m)
  91. {
  92. dij.init();
  93. repu(i,,m)
  94. {
  95. scanf("%d%d%d",&a,&b,&c);
  96. dij.AddEdge(a,b,c);
  97. dij.AddEdge(b,a,c);
  98. }
  99. dij.dijkstra(,n);
  100. printf("%d\n",dij.d[n]);
  101. }
  102. return ;
  103. }

堆优化的Dij

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstdlib>
  4. #include <algorithm>
  5. #include <cstring>
  6. #include <cmath>
  7. #include <vector>
  8. #include <queue>
  9. #include <stack>
  10. #include <set>
  11. #include <map>
  12. using namespace std;
  13. const int maxn=;
  14. const int INF=0x3f3f3f3f;
  15. struct Edge
  16. {
  17. int u, v, d;
  18. Edge(int u, int v, int d):u(u), v(v), d(d) {}
  19. };
  20. struct qnode
  21. {
  22. int u,d;
  23. qnode(int u, int d):u(u), d(d) {}
  24. bool operator < (const qnode a)const
  25. {
  26. return d>a.d;
  27. }
  28. };
  29. struct Dijkstra
  30. {
  31. int n;
  32. vector<int> G[maxn];
  33. vector<Edge> edge;
  34. int d[maxn];
  35. bool vis[maxn];
  36. void init(int n)
  37. {
  38. this->n = n;
  39. for(int i=; i<=n; i++)
  40. {
  41. G[i].clear();
  42. vis[i]=;
  43. d[i]=INF;
  44. }
  45. edge.clear();
  46. }
  47. void AddEdge(int u, int v, int d)
  48. {
  49. G[u].push_back(edge.size());
  50. edge.push_back(Edge(u, v, d));
  51. }
  52. void dijkstra(int s)
  53. {
  54. priority_queue<qnode> q;
  55. d[s]=;
  56. q.push(qnode(s, ));
  57. while(!q.empty())
  58. {
  59. qnode x=q.top();
  60. q.pop();
  61. if(vis[x.u])
  62. continue ;
  63. vis[x.u]=true;
  64. for(int i=; i<G[x.u].size(); i++)
  65. {
  66. Edge& e=edge[G[x.u][i]];
  67. if(d[e.v]>d[x.u]+e.d)
  68. {
  69. d[e.v]=d[x.u]+e.d;
  70. q.push(qnode(e.v, d[e.v]));
  71. }
  72. }
  73. }
  74. }
  75. } dij;
  76.  
  77. int main()
  78. {
  79. int n, m;
  80. while(scanf("%d%d", &n, &m),n+m)
  81. {
  82. dij.init(n);
  83. while(m--)
  84. {
  85. int u, v, w;
  86. scanf("%d%d%d", &u, &v, &w);
  87. dij.AddEdge(u, v, w);
  88. dij.AddEdge(v, u, w);
  89. }
  90. dij.dijkstra();
  91. printf("%d\n",dij.d[n]);
  92. }
  93. return ;
  94. }

邻接矩阵Dij

本来以为这两个时间效率相差会很大,看来只在稠密图中奏效。

当图稠密起来后一般需要用堆优化的dijkstra。。。

HDU2544 最短路dij的更多相关文章

  1. 天梯赛 L2-001 紧急救援 (最短路 dij)

    作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上.当其他城市有紧急求 ...

  2. HDU 6071 Lazy Running (同余最短路 dij)

    Lazy Running Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others)To ...

  3. HDU-2544 最短路 Dijkstra模板题

    题目链接:https://vjudge.net/problem/HDU-2544 题意: 题目要求找到节点1到节点n之间的一条最短路 分析: Dijkstra模板题 单源最短路径,可以用dijkstr ...

  4. hdu2544 最短路 Dijkstra算法

    最短路(Dijkstra算法模板题) Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  5. HDU2544 最短路 2017-04-12 18:51 31人阅读 评论(0) 收藏

    最短路 Time Limit : 5000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submissio ...

  6. hdu2544最短路(floyd基础)

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  7. HDU2544最短路模板,

    #include<iostream> #include<stdio.h> #include<stdlib.h> #include<algorithm> ...

  8. 最短路径(最基础,经典的模板和思想):HDU-2544最短路

    题目: 最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  9. [hdu2544]最短路spfa

    解题关键:最短路模板一直没整理过,这里整理了一下spfa+链式前向星建图的最短路模板,以后网络赛省的打了. spfa算法的关键就是松弛操作,只有进行松弛操作,其后的点距离才可能被更新. #includ ...

随机推荐

  1. spring beans

    所 有 使 用 XML 文 件 进 行 配 置 信 息 加 载 的 Spring IoC 容 器 , 包 括 BeanFactory 和ApplicationContext的所有XML相应实现,都使用 ...

  2. @@identity的使用

    -- ============================================= -- Author: Qiuhua,Huang -- Create date: 08/09/2012 ...

  3. 16090202(剑灵GPA)

    [目标] 剑灵GPA [思路] 1 2 绘制角色DrawCall body 5526面片 2.1[第一个DrawCall]63 RT 这个DrawCall PS VS 参数列表 VS // // Ge ...

  4. Windows中一个22年的漏洞

     X Windows系统,今天作为世界各地的Linux桌面,已经存在超过20年了,仍然存在Bug.几天前Sysadmins为libXfont库提供了补丁,来对应新发现的已经在代码中存在了22年的特权升 ...

  5. mongo virtual

    var options={"upsert":false,"multi":false,'new':false}; 不存是否插入,更新是否批量,返回内容是更新前还是 ...

  6. 发布自己的pods到CocoaPods trunk 及问题记录

    这两天准备把之前写的一些小玩意添加到pods库中去,参考了一些资料后进行操作,实际中也遇到了一些问题,记录下来,问题及解决方式在后面. 参考内容转载如下: 首先更新了用trunk之后,CocoaPod ...

  7. [导读]Learning from Imbalanced Classes

    原文:Learning from Imbalanced Classes 数据不平衡是一个非常经典的问题,数据挖掘.计算广告.NLP等工作经常遇到.该文总结了可能有效的方法,值得参考: Do nothi ...

  8. SVN相关

    Eclipse SVN忽略一些文件夹:Windows -> Preferences -> Team -> Ignored Resources里点 “Add Pattern”,然后把 ...

  9. jquery qrcode参数

    { // render method: 'canvas', 'image' or 'div' render: 'canvas', // version range somewhere in 1 .. ...

  10. CSS3入门--线条动画特效实例

    HTML: <div></div> CSS: div{ width: 200px; height: 200px; margin: 200px auto; background: ...