結果

提出番号 1690
提出者 shibh308
言語 C++
提出日時 2018-08-04 13:30:47
問題名 (73)観光計画
結果 WA
点数 0%

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 WA 0% 132ms 57488KB
2 WA 0% 150ms 68080KB
3 WA 0% 72ms 41952KB
4 WA 0% 204ms 86544KB
5 WA 0% 89ms 50160KB
6 WA 0% 143ms 75296KB
7 AC 100% 194ms 91056KB
8 AC 100% 195ms 94752KB
9 WA 0% 97ms 48352KB
10 AC 100% 241ms 104704KB
11 WA 0% 94ms 52880KB
12 AC 100% 40ms 31920KB
13 WA 0% 97ms 60768KB
14 WA 0% 234ms 97808KB
15 WA 0% 170ms 81008KB
16 WA 0% 158ms 72480KB
17 WA 0% 208ms 96928KB
18 WA 0% 133ms 67904KB
19 WA 0% 37ms 30416KB
20 WA 0% 111ms 62976KB
21 WA 0% 51ms 33872KB
22 WA 0% 85ms 51184KB
23 WA 0% 106ms 53936KB
24 WA 0% 282ms 122272KB
25 WA 0% 215ms 90544KB
26 WA 0% 226ms 99376KB
27 WA 0% 61ms 35360KB
28 WA 0% 57ms 29648KB
29 WA 0% 122ms 63200KB
30 WA 0% 101ms 62304KB
31 WA 0% 256ms 110288KB
32 WA 0% 127ms 67808KB
33 WA 0% 28ms 21424KB
34 WA 0% 179ms 90032KB
35 WA 0% 32ms 21200KB
36 WA 0% 189ms 90896KB
37 WA 0% 94ms 45648KB
38 WA 0% 22ms 14864KB
39 WA 0% 280ms 118752KB
40 WA 0% 36ms 29648KB
41 WA 0% 240ms 99344KB
42 AC 100% 65ms 34192KB
43 WA 0% 290ms 113584KB
44 WA 0% 148ms 66032KB
45 WA 0% 154ms 78528KB
46 WA 0% 152ms 75504KB
47 WA 0% 231ms 101776KB
48 WA 0% 250ms 103136KB
49 WA 0% 115ms 62384KB
50 WA 0% 200ms 92320KB
51 WA 0% 51ms 27536KB
52 WA 0% 120ms 58160KB
53 WA 0% 77ms 38672KB
54 WA 0% 171ms 78896KB
55 WA 0% 48ms 31888KB
56 WA 0% 144ms 74896KB
57 WA 0% 77ms 54944KB
58 WA 0% 103ms 49392KB
59 WA 0% 55ms 36000KB
60 WA 0% 65ms 39152KB
61 WA 0% 85ms 49232KB
62 WA 0% 200ms 86800KB
63 WA 0% 153ms 89728KB
64 WA 0% 234ms 92576KB
65 WA 0% 195ms 87968KB
66 AC 100% 6ms 13840KB
67 WA 0% 122ms 65424KB
68 WA 0% 124ms 75040KB
69 WA 0% 334ms 130528KB
70 WA 0% 156ms 69776KB

ソースコード

// g++ macro.cpp -std=c++14
#include <bits/stdc++.h>
typedef long long ll;
const int INF = 1e9;
const int MOD = 1e9+7;
const ll LINF = 1e18;
using namespace std;
 
#define dump(x)  cout << #x << " = " << (x) << endl;
#define YES(n) cout << ((n) ? "YES" : "NO"  ) << endl
#define Yes(n) cout << ((n) ? "Yes" : "No"  ) << endl
#define POSSIBLE(n) cout << ((n) ? "POSSIBLE" : "IMPOSSIBLE"  ) << endl
#define Possible(n) cout << ((n) ? "Possible" : "Impossible"  ) << endl
#define possible(n) cout << ((n) ? "possible" : "impossible"  ) << endl
 
#define SANKOU(n,a,b) cout << ((n) ? (#a) : (#b) ) << endl
 
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define REP(i,n) for(int i=0;i<(n);++i)
#define REPR(i,n) for(int i=n;i>=0;i--)
 
#define FOREACH(x,a) for(auto& (x) : (a) )
 
#define WFA(d,v) REP(k,v)REP(i,v)REP(j,v)d[i][j]=min(d[i][j],d[i][k]+d[k][j])
 
#define SCOUT(x) cout<<(x)<<" "
#define ENDL cout<<endl
 
#define VECCIN(x) for(auto&youso_: (x) )cin>>youso_
#define VECIN2(x,y) REP(i,x.size())cin>>x[i]>>y[i]
#define VECCOUT(x) if(1){for(auto tt=x.begin();tt!=x.end();tt++){if(tt!=x.begin())cout<<" ";cout<<(*tt);}cout<<endl;}
 
#define ALL(obj) (obj).begin(),(obj).end()
 
#define EXIST(n,x) (find(ALL(n),x)!=n.end())
#define UNIQUE(obj) sort(ALL( obj )); obj.erase(unique(ALL(obj)),obj.end())
#define EN(x) if(1){cout<<#x<<endl;return 0;}
#define COUT(x) cout<<(x)<<endl
void CINT(){}
template <class Head,class... Tail>
void CINT(Head&& head,Tail&&... tail){
    cin>>head;
    CINT(move(tail)...);
}
#define CIN(...) int __VA_ARGS__;CINT(__VA_ARGS__)
#define LCIN(...) ll __VA_ARGS__;CINT(__VA_ARGS__)
#define SCIN(...) string __VA_ARGS__;CINT(__VA_ARGS__)
 
template <class T = ll>
T IN(){T x;cin>>x;return (x);}
 
template <class Head>
void VT(Head head){}
template <class Head,class Seco,class... Tail>
void VT(Head&& head,Seco&& seco,Tail&&... tail){
    seco.resize(head);
    VT(head,move(tail)...);
}
void VT2(){}
template <class Head,class... Tail>
void VT2(Head&& head,Tail&&... tail){
  VECCIN(head);
  VT2(move(tail)...);
}
 
template <class Head>
void VT3(Head&& head){}
template <class Head,class Seco,class... Tail>
void VT3(Head&& head,Seco&& seco,Tail&&... tail){
  seco[head]=IN();
  VT3(head,move(tail)...);
}
 
#define VC1(n,...) V __VA_ARGS__;VT(n,__VA_ARGS__);VT2(__VA_ARGS__); //aaabbbccc
#define VC2(n,...) V __VA_ARGS__;VT(n,__VA_ARGS__);REP(i,n)VT3(i,__VA_ARGS__); //abcabcabc
 
// #include <boost/multiprecision/cpp_int.hpp>
// using namespace boost::multiprecision; // cpp_int
 
#define P pair<ll,ll>
#define V vector<ll>
#define M map<ll,ll>
#define S set<ll>
 
#define pb(a) push_back(a)
#define mp make_pair

class Dijkstra{
public:
    Dijkstra(vector<vector<P>> ed,ll firs,ll pnum);
    void Solve();
    V range;// range[a]=b;
    vector<vector<P>> edges;// [a][b]=c;
    priority_queue<P,vector<P>,greater<P>> que;// queue=(range,poll);
    V keiro;
    V CalcRoute(ll startp,ll endp);
};

Dijkstra::Dijkstra(vector<vector<P>> ed,ll firs,ll pnum){
    edges=ed;
    V ttt(pnum,LINF);
    range=ttt;
    range[firs]=0;
    que.push(mp(0,firs));
    keiro=V(pnum);
    REP(i,pnum)keiro[i]=i;
}

void Dijkstra::Solve(){
    while(!que.empty()){
        P top_=que.top();
        que.pop();
        FOREACH(x,edges[top_.second]){
            if(range[x.first] > range[top_.second] + x.second){
                range[x.first] = range[top_.second] + x.second;
                que.push(mp(range[x.first],x.first));
                keiro[x.first] = top_.second;
            }
        }
    }
}

V Dijkstra::CalcRoute(ll startp,ll endp){
  V vec(1,endp);
  ll poll = endp;
  while(poll==startp){
    poll = keiro[poll];
    vec.pb(poll);
  }
  return vec;
}



int main(){
  CIN(n,m,k);
  VC2(m,a,b,c);
  VC2(k,h,d);
  vector<vector<P>> edges(n+1);
  REP(i,m){
    edges[a[i]].pb(mp(b[i],c[i]));
    edges[b[i]].pb(mp(a[i],c[i]));
  }
  REP(i,k)
    edges[n].pb(mp(h[i], 1LL*(1e6 - d[i])));
  
  Dijkstra dijk(move(edges), n, n+1);
  dijk.Solve();

  int cnt = 0;
  REP(i,n)
    cnt += dijk.range[i] <= 1e6;
  COUT(cnt);

  

  return 0;
}