結果

提出番号 1784
提出者 dohatsutsu
言語 C++
提出日時 2018-08-04 13:52:24
問題名 (73)観光計画
結果 AC
点数 100%

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 AC 100% 124ms 41168KB
2 AC 100% 142ms 45216KB
3 AC 100% 59ms 27760KB
4 AC 100% 188ms 55200KB
5 AC 100% 99ms 37568KB
6 AC 100% 161ms 51712KB
7 AC 100% 162ms 53728KB
8 AC 100% 184ms 53184KB
9 AC 100% 93ms 34416KB
10 AC 100% 211ms 67472KB
11 AC 100% 94ms 36848KB
12 AC 100% 36ms 22384KB
13 AC 100% 97ms 34576KB
14 AC 100% 214ms 58464KB
15 AC 100% 162ms 48832KB
16 AC 100% 130ms 49456KB
17 AC 100% 188ms 60928KB
18 AC 100% 142ms 46688KB
19 AC 100% 34ms 27312KB
20 AC 100% 100ms 37120KB
21 AC 100% 58ms 30288KB
22 AC 100% 91ms 33776KB
23 AC 100% 97ms 34832KB
24 AC 100% 272ms 69168KB
25 AC 100% 183ms 60224KB
26 AC 100% 189ms 61040KB
27 AC 100% 56ms 25936KB
28 AC 100% 53ms 26480KB
29 AC 100% 133ms 44672KB
30 AC 100% 92ms 38928KB
31 AC 100% 247ms 67152KB
32 AC 100% 145ms 46368KB
33 AC 100% 32ms 21088KB
34 AC 100% 169ms 56912KB
35 AC 100% 27ms 20544KB
36 AC 100% 158ms 50112KB
37 AC 100% 91ms 33520KB
38 AC 100% 21ms 19216KB
39 AC 100% 218ms 62816KB
40 AC 100% 32ms 21200KB
41 AC 100% 218ms 61056KB
42 AC 100% 60ms 28448KB
43 AC 100% 219ms 69536KB
44 AC 100% 135ms 44064KB
45 AC 100% 160ms 48928KB
46 AC 100% 168ms 49776KB
47 AC 100% 231ms 61408KB
48 AC 100% 198ms 63008KB
49 AC 100% 132ms 43840KB
50 AC 100% 197ms 52016KB
51 AC 100% 49ms 25536KB
52 AC 100% 117ms 39472KB
53 AC 100% 63ms 30384KB
54 AC 100% 166ms 50976KB
55 AC 100% 43ms 24032KB
56 AC 100% 123ms 39984KB
57 AC 100% 70ms 34512KB
58 AC 100% 91ms 36608KB
59 AC 100% 46ms 30352KB
60 AC 100% 61ms 27536KB
61 AC 100% 96ms 33776KB
62 AC 100% 189ms 55680KB
63 AC 100% 154ms 47424KB
64 AC 100% 206ms 58736KB
65 AC 100% 196ms 53056KB
66 AC 100% 6ms 15920KB
67 AC 100% 117ms 41008KB
68 AC 100% 111ms 39072KB
69 AC 100% 301ms 77936KB
70 AC 100% 143ms 46512KB

ソースコード

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
struct edge{
  ll to,cost;
  edge(ll to,ll cost) : to(to), cost(cost) {}
};

ll N,M,K;
vector< ll > d,h;
vector< edge > G[100005];


int main(){
  cin>>N>>M>>K;
  for(int i=0;i<M;i++){
    ll a,b,c;
    cin>>a>>b>>c;
    a--,b--;
    G[a].push_back( edge(b,c) );
    G[b].push_back( edge(a,c) );
  }
  
  h.resize(K);
  d.resize(K);

  const ll tmp = (1LL<<30);
  
  for(int i=0;i<K;i++){
    cin>>h[i]>>d[i];
    h[i]--;

    G[ N ].push_back( (edge){ h[i], tmp - d[i] } );
  }

  vector<ll> dist( N+1 , (1LL<<60) );
  dist[ N ] = 0;
  typedef pair<ll,ll> P;
  priority_queue< P , vector<P> , greater<P> > Q;
  Q.push( P(0,N) );
  while(!Q.empty()){
    P p=Q.top();
    Q.pop();
    ll pos=p.second;
    ll cost=p.first;
    if( dist[pos] < cost )continue;
    for(int i=0;i<(int)G[pos].size();i++){
      edge e=G[pos][i];
      if( cost + e.cost < dist[ e.to ] ){
        dist[ e.to ] = cost + e.cost;
        Q.push( P( dist[e.to] , e.to ) );
      }
    }
  }

  ll ans=0;
  for(int i=0;i<N;i++)
    if( dist[i] <= tmp )ans++;
  cout<<ans<<endl;
  return 0;
}