码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 1874(简单最短路)

时间:2015-12-03 13:19:08      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:

优先队列那里用greater会报错

http://acm.hdu.edu.cn/showproblem.php?pid=1874

 

 1 /*
 2 使用pair代替结构
 3 */
 4 
 5 #include <iostream>
 6 #include <cstdio>
 7 #include <queue>
 8 #include <vector>
 9 using namespace std;
10 const int Ni = 10000;
11 const int INF = 1<<27;
12 
13 typedef pair<int,int> pa;
14 
15 int dis[Ni],n;//dis使用1-n的部分
16 
17 vector<pair<int,int> > eg[Ni];
18 
19 void Dijkstra(int s)
20 {
21           int i,j;
22           for(i=0;i<=n;i++)//要到n
23                     dis[i] = INF;
24           priority_queue<pa> q;  //优先级队列:小顶堆
25           dis[s] = 0;
26           q.push(make_pair(s,dis[s]));
27 
28           while(!q.empty())
29           {
30                     pa x = q.top();
31                     q.pop();
32                     int w = x.first;
33                     for(j = 0;j<eg[w].size();j++)//遍历x的所有邻接点
34                     {
35                               pa y = eg[w][j];//y是x的邻接点
36                               int u = y.first;
37                               if(dis[u]>x.second+y.second)
38                               {
39                                         dis[u] = x.second+y.second;
40                                         q.push(make_pair(u,dis[u]));
41                               }
42                     }
43           }
44 
45 }
46 
47 
48 int main()
49 {
50           int m,a,b,d;//关系个数
51           while(cin>>n>>m)
52           {
53                     for(int i = 0;i<=n;i++)
54                               eg[i].clear();//初始化
55                     while(m--)
56                     {
57                               cin>>a>>b>>d;
58                               eg[a].push_back(make_pair(b,d));
59                               eg[b].push_back(make_pair(a,d));
60                     }
61 
62                     int o,p;
63                     cin>>o>>p;
64                     Dijkstra(o);
65                     if(dis[p]!=INF)
66                               cout<<dis[p]<<endl;
67                     else
68                               cout<<"-1\n";
69           }
70 
71           return 0;
72 }
73 /*
74 6 6
75 1 2 2
76 3 2 4
77 1 4 5
78 2 5 2
79 3 6 3
80 5 6 3
81 */

 

HDU 1874(简单最短路)

标签:

原文地址:http://www.cnblogs.com/qlky/p/5015740.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!