图论-Dijkstra(堆优化)模板

 测试题目:NKOJ1120 NKOJ3639

 

 1 #include <stdio.h>
 2 #include <vector>
 3 #include <queue>
 4 
 5 using namespace std;
 6 
 7 typedef long long LL;
 8 
 9 const int _N = 420000;
10 const long long INF = 99999999999999LL;
11 
12 LL n, m;
13 LL dis[_N];
14 
15 struct node {
16     LL v, w;
17     node(const LL &_v, const LL &_w):
18         v(_v), w(_w) {}
19 };
20 
21 struct strdis {
22     LL v, dis;
23     strdis(const LL &_v, const LL &_dis):
24         v(_v), dis(_dis) {}
25     bool operator < (const strdis &tmp) const
26     {
27         return this->dis > tmp.dis;
28     }
29 };
30 
31 vector<node> G[_N];
32 priority_queue<strdis> Q;
33 
34 void Dijkstra(int beg)
35 {
36     LL i;
37     for (i = 1; i <= n; ++i) dis[i] = INF;
38     dis[beg] = 0;
39     while (!Q.empty()) Q.pop();
40     Q.push(strdis(beg, dis[beg]));
41     while (!Q.empty()) {
42         LL p = Q.top().v;
43         vector<node>::iterator it;
44         if (Q.top().dis != dis[p]) { Q.pop(); continue; }
45         for (it = G[p].begin(); it != G[p].end(); ++it) {
46             if (dis[it->v] <= dis[p] + it->w) continue;
47             dis[it->v] = dis[p] + it->w;
48             Q.push(strdis(it->v, dis[it->v]));
49         }
50         Q.pop();
51     }
52     return ;
53 }
54 
55 int main()
56 {
57     LL i, t1, t2, t3;
58     scanf("%lld%lld", &n, &m);
59     for (i = 1; i <= m; ++i) {
60         scanf("%lld%lld%lld", &t1, &t2, &t3);
61         G[t1].push_back(node(t2, t3));
62     }
63     scanf("%lld%lld", &t1, &t2);
64     Dijkstra(t1);
65     printf("%lld\n", dis[t2]);
66     return 0;
67 }
View Code

 

posted @ 2017-12-17 03:42  derchg  阅读(188)  评论(0编辑  收藏  举报