zoukankan      html  css  js  c++  java
  • UVA 10896 Sending Email

    这个题目真是伤透脑筋了,一直RE,连着改了好几个版本,又是spfa,又是单调队列dijkstra+单调队列,总是不过,后来发现M开小了,双向边应该开m的两倍,悲剧啊!!!以后不管怎样,数组一定要尽量开大点。

    折磨的真是痛苦,不过发现了一样好东西,http://uvatoolkit.com/problemssolve.php

    uva一个测试工具,输入数据能够给出正确结果,以后不用辛苦到网上找AC代码了,直接输入结果。

     1 #include <cstdio>
     2 #include <cstring>
     3 #include <queue>
     4 #include <cstdlib>
     5 #define N 20010
     6 #define M 100010
     7 #define INF 0x0f0f0f0f
     8 
     9 using namespace std;
    10 typedef pair<int,int> pii;
    11 
    12 int next[M],first[M],to[M],w[M];
    13 int d[N],p;
    14 
    15 void add(int u,int v,int t)
    16 {
    17     to[p] = v;
    18     w[p] = t;
    19     next[p] = first[u];
    20     first[u] = p++;
    21 }
    22 
    23 int main(void)
    24 {
    25     int T;
    26     for(int t = scanf("%d",&T); t <= T; t++)
    27     {
    28         priority_queue <pii, vector<pii>, greater<pii> > q;
    29         p = 0;
    30         memset(first,-1,sizeof(first));
    31         int sr,ta,n,m,u,v,c;
    32         scanf("%d%d%d%d",&n,&m,&sr,&ta);
    33         for(int i=0;i<m;i++)
    34         {
    35             scanf("%d%d%d",&u,&v,&c);
    36             add(u,v,c);
    37             add(v,u,c);
    38         }
    39         memset(d,0x0f,sizeof(d));
    40         d[sr] = 0;
    41         q.push(make_pair(d[sr],sr));
    42         while(!q.empty())
    43         {
    44             pii u = q.top();q.pop();
    45             int x = u.second;
    46             if(u.first != d[x])
    47                 continue;
    48             for(int e = first[x]; e != -1; e = next[e])
    49                 if(d[to[e]] > d[x]+w[e])
    50             {
    51                 d[to[e]] = d[x] + w[e];
    52                 q.push(make_pair(d[to[e]],to[e]));
    53             }
    54         }
    55         printf("Case #%d: ",t);
    56         if(d[ta]==INF)
    57             puts("unreachable");
    58         else printf("%d
    ",d[ta]);
    59     }
    60     return 0;
    61 }
  • 相关阅读:
    《JavaScript 闯关记》之初探
    《JavaScript 闯关记》之简介
    《JavaScript 闯关记》
    JavaScript检测之basevalidate.js
    如何排版 微信公众号「代码块」
    android开发之路03
    android开发之路02(浅谈BroadcastReceiver)
    android开发之路01
    软件工程复习(一)
    软件工程—人件(一)
  • 原文地址:https://www.cnblogs.com/rootial/p/3297554.html
Copyright © 2011-2022 走看看