首页 > 其他 > 详细

cf 20C Dijkstra?

时间:2014-08-13 00:47:14      阅读:377      评论:0      收藏:0      [点我收藏+]

带队列  dijkstra

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <queue>
 4 #include <vector>
 5 #include<memory.h>
 6 #include<algorithm>//reverse
 7 using namespace std;
 8 #define maxn 100002
 9 #define INF 65
10 struct node
11 {
12     int u;
13     int w;
14     node(long long x,long long y)
15     {
16         u = x;
17         w = y;
18     }
19     bool operator < ( const node& p ) const
20     {      return w > p.w;   }
21 };
22 vector<long long>g[maxn];
23 vector<long long>cost[maxn];
24 long long d[maxn];
25 long long par[maxn];
26 int dijk(int n)
27 {
28     memset(d, INF, sizeof(d));
29     memset(par, -1, sizeof(par));
30     priority_queue<node>q;
31     q.push(node(1,0));
32     d[1]=0;
33     while(!q.empty())
34     {
35         node top = q.top();
36         q.pop();
37         int uu = top.u;
38         if(uu == n) return d[n];
39         for(int i = 0;i < g[uu].size(); i++)
40         {
41             int v = g[uu][i];
42             if(d[uu] + cost[uu][i] < d[v])
43             {
44                 d[v] = d[uu] + cost[uu][i];
45                 par[v] = uu;
46                 q.push(node(v,d[v]));
47             }
48         }
49     }
50     return -1;
51 }
52 int main()
53 {
54     //freopen("input.txt","r",stdin);
55     int n,e,u,v;
56     long long w;
57     cin>>n>>e;
58     for(int i = 0; i < e; i++)
59     {
60         cin>>u>>v>>w;
61         g[u].push_back(v);cost[u].push_back(w);
62         g[v].push_back(u);cost[v].push_back(w);
63 
64     }
65     w = dijk(n);
66     if(w == -1) cout<<"-1"<<endl;
67     else
68     {
69         int t = n;
70         int s[maxn];
71         int k = 0;
72         while(t != -1)
73         {
74             s[k++] = t;
75             t = par[t];
76         }
77         for(int j = k - 1; j >= 0; j--)
78             cout<<s[j]<<" ";
79         cout<<endl;
80     }
81 }

 

cf 20C Dijkstra?,布布扣,bubuko.com

cf 20C Dijkstra?

原文:http://www.cnblogs.com/imLPT/p/3908632.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!