zoukankan      html  css  js  c++  java
  • poj 1511 优先队列优化dijkstra *

    题意:两遍最短路

    链接:点我

    注意结果用long long

      1 #include<cstdio>
      2 #include<iostream>
      3 #include<algorithm>
      4 #include<cstring>
      5 #include<cmath>
      6 #include<queue>
      7 #include<map>
      8 using namespace std;
      9 #define MOD 1000000007
     10 #define pb(a) push_back(a)
     11 const int INF=0x3f3f3f3f;
     12 const double eps=1e-5;
     13 typedef long long ll;
     14 #define cl(a) memset(a,0,sizeof(a))
     15 #define ts printf("*****
    ");
     16 const int MAXN=1000005;
     17 int p[MAXN],q[MAXN],w[MAXN];
     18 int n,m,tt,cnt;
     19 /*
     20 * 使用优先队列优化Dijkstra算法
     21 * 复杂度O(ElogE)
     22 * 注意对vector<Edge>E[MAXN]进行初始化后加边
     23 */
     24 struct qnode
     25 {
     26 int v;
     27 int c;
     28 qnode(int _v=0,int _c=0):v(_v),c(_c){}
     29 bool operator <(const qnode &r)const
     30 {
     31 return c>r.c;
     32 }
     33 };
     34 struct Edge
     35 {
     36 int v,cost;
     37 Edge(int _v=0,int _cost=0):v(_v),cost(_cost){}
     38 };
     39 vector<Edge>E[MAXN];
     40 bool vis[MAXN];
     41 int dist[MAXN];
     42 void Dijkstra(int n,int start)//点的编号从1开始
     43 {
     44 memset(vis,false,sizeof(vis));
     45 for(int i=1;i<=n;i++)dist[i]=INF;
     46 priority_queue<qnode>que;
     47 while(!que.empty())que.pop();
     48 dist[start]=0;
     49 que.push(qnode(start,0));
     50 qnode tmp;
     51 while(!que.empty())
     52 {
     53 tmp=que.top();
     54 que.pop();
     55 int u=tmp.v;
     56 if(vis[u])continue;
     57 vis[u]=true;
     58 for(int i=0;i<E[u].size();i++)
     59 {
     60 int v=E[tmp.v][i].v;
     61 int cost=E[u][i].cost;
     62 if(!vis[v]&&dist[v]>dist[u]+cost)
     63 {
     64 dist[v]=dist[u]+cost;
     65 que.push(qnode(v,dist[v]));
     66 }
     67 }
     68 }
     69 }
     70 void addedge(int u,int v,int w)
     71 {
     72 E[u].push_back(Edge(v,w));
     73 }
     74 int main()
     75 {
     76     int i,j,k;
     77     #ifndef ONLINE_JUDGE
     78     freopen("1.in","r",stdin);
     79     #endif
     80     scanf("%d",&tt);
     81     while(tt--)
     82     {
     83         scanf("%d%d",&n,&m);
     84         for(i=0;i<=n;i++)    E[i].clear();
     85         for(i=0;i<m;i++)
     86         {
     87             scanf("%d%d%d",&p[i],&q[i],&w[i]);
     88             addedge(p[i],q[i],w[i]);
     89         }
     90         Dijkstra(n,1);
     91         ll sum=0;
     92         for(i=2;i<=n;i++)
     93         {
     94             sum+=dist[i];
     95         }
     96         for(i=0;i<=n;i++)    E[i].clear();
     97         for(i=0;i<m;i++)    addedge(q[i],p[i],w[i]);
     98         Dijkstra(n,1);
     99         for(i=2;i<=n;i++)
    100         {
    101             sum+=dist[i];
    102         }
    103         printf("%I64d
    ",sum);
    104     }
    105 }
  • 相关阅读:
    struts1——静态ActionForm与动态ActionForm
    【入门篇】ANDROID开发之BUG专讲
    oracle undo 复杂度--oracle核心技术读书笔记四
    linux高级技巧:rsync同步(二)
    【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字
    一维动态数组和二维动态数组的创建和使用
    HDU 1788 Chinese remainder theorem again 中国剩余定理
    直接选择排序
    使用enca进行字符集转码
    拒绝switch,程序加速之函数指针数组
  • 原文地址:https://www.cnblogs.com/cnblogs321114287/p/4590297.html
Copyright © 2011-2022 走看看