题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544

这题的思路可以见这里(同一类型):http://blog.csdn.net/xiaozhuaixifu/article/details/9232921

  1. #include<iostream>
  2. using namespace std;
  3. const int maxn=101;
  4. const int intmax=99999;
  5. int weight[maxn][maxn]; //保存权值的邻接矩阵
  6. int dis[maxn];
  7. int s,t;
  8. void dijkstra()
  9. {
  10. bool Sset[maxn];
  11. memset(Sset,0,sizeof(Sset));
  12. Sset[s]=1;
  13. for(int i=0;i<maxn;i++)
  14. {
  15. int u,v;
  16. int tmp=intmax;
  17. for(int i=0;i<maxn;i++)
  18. {
  19. if(!Sset[i]&&dis[i]<tmp)
  20. {
  21. u=i;
  22. tmp=dis[i];
  23. }
  24. }
  25. Sset[u]=1;
  26. for(int i=0;i<maxn;i++)
  27. {
  28. if(!Sset[i]&&weight[u][i]<intmax)
  29. {
  30. int newdis=dis[u]+weight[u][i];
  31. if(newdis<dis[i])dis[i]=newdis;
  32. }
  33. }
  34. }
  35. }
  36. int main()
  37. {
  38. int n,m;
  39. while(cin>>n>>m)
  40. {
  41. if(n==0&&m==0)break;
  42. int a,b,x;
  43. for(int i=1;i<maxn;i++)
  44. for(int j=1;j<maxn;j++)
  45. weight[i][j]=intmax;
  46. for(int i=0;i<m;i++)
  47. {
  48. cin>>a>>b>>x;
  49. if(x<weight[a][b]) //处理重边
  50. weight[a][b]=weight[b][a]=x;
  51. }
  52. // cin>>s>>t;
  53. for(int i=0;i<maxn;i++)dis[i]=weight[1][i];
  54. dis[1]=0; //如果是起点到起点,则应该是0
  55. dijkstra();
  56. if(dis[n]<intmax)
  57. cout<<dis[n]<<endl;
  58. else cout<<-1<<endl; //不存的情况应该是:权值无穷大
  59. }
  60. return 0;
  61. }

HDOJ/HDU 2544 最短路---dijkstra算法的更多相关文章

  1. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  2. hdu 2544 最短路 Dijkstra

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...

  3. HDU 2544最短路dijkstra模板题

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

  4. HDU 2544 最短路(dijkstra+邻接矩阵)

    ( ̄▽ ̄)" #include<iostream> #include<cstdio> using namespace std; const int INF=10e7; ...

  5. HDU - 2544最短路 (dijkstra算法)

    HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...

  6. UESTC 30 &&HDU 2544最短路【Floyd求解裸题】

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

  7. 单源最短路dijkstra算法&&优化史

    一下午都在学最短路dijkstra算法,总算是优化到了我能达到的水平的最快水准,然后列举一下我的优化历史,顺便总结总结 最朴素算法: 邻接矩阵存边+贪心||dp思想,几乎纯暴力,luoguTLE+ML ...

  8. HUD.2544 最短路 (Dijkstra)

    HUD.2544 最短路 (Dijkstra) 题意分析 1表示起点,n表示起点(或者颠倒过来也可以) 建立无向图 从n或者1跑dij即可. 代码总览 #include <bits/stdc++ ...

  9. 最短路Dijkstra算法的一些扩展问题

    最短路Dijkstra算法的一些扩展问题     很早以前写过关于A*求k短路的文章,那时候还不明白为什么还可以把所有点重复的放入堆中,只知道那样求出来的就是对的.知其然不知其所以然是件容易引发伤痛的 ...

随机推荐

  1. 现代的新语言--Swift初探

    新的语言 WWDC简短的介绍,新的语言Swift就问世了,尽管新语言的名字导致贴吧下歌手粉丝和开发人员们争抢地盘- -,只是雨燕就是这么来了. WWDC keynote里给Swift打上了非常多标签: ...

  2. 手游2dx面试笔记一

    第一轮IQ测试:都来面试程序了,相信IQ再怎么也坑不到哪里去吧.要问什么样的题,几页纸呐, 如:1.找出不同类:羚羊.斑马.鲨鱼 2.在()里添一字使2边都能组词:木()料 3.中间值?:1,2,4, ...

  3. WSAWaitForMultipleEvents()

    简述:只要指定事件对象中的一个或全部处于有信号状态,或者超时间隔到,则返回. #include <winsock2.h> DWORD WSAAPI WSAWaitForMultipleEv ...

  4. asp.net 5.0微信支付

    (原文出自:http://lib.csdn.net/article/wechat/46329) 微信支付官方坑太多,我们来精简 我把官方的代码,打包成了 an.wxapi.dll. 里面主要替换了下注 ...

  5. MVC路由规则以及前后台获取Action、Controller、ID名方法

    1.前后台获取Action.Controller.ID名方法 前台页面:ViewContext.RouteData.Values["Action"].ToString(); Vie ...

  6. polya定理小结

    polya的精髓就在与对循环节的寻找,其中常遇到的问题就是项链染色类问题. 当项链旋转时有n种置换,循环节的个数分别是gcd(n, i); 当项链翻转时有n种置换,其中当项链珠子数位奇数时,循环节的个 ...

  7. Linux Shell脚本入门--(linux空设备文件和重定向)>/dev/null 2>&1

    linux空设备文件和重定向 输出/输入重导向 >      >>   <   <<   :>   &>   2&>   2< ...

  8. MySQL简单查询

    1.普通查询 select * from info; #查询所有内容 select Code,Name from Info #查询某几列 2.条件查询 select * from Info where ...

  9. ECSTORE2.0 新增自定义定时任务

    在ECsotre系统里面添加一个自定义的定时任务,可以完成一些自动化处理,例如自动确认订单或者是删除无效订单的,可以很方便的实现各种定时执行的任务,下面简单介绍下怎么添加定时任务. 在自己的app目录 ...

  10. div弹出登录窗口

    <meta charset="utf-8"/> <script type="text/javascript"> //弹出式登录 func ...