結果

問題 No.1 道のショートカット
ユーザー 0w10w1
提出日時 2016-11-21 20:49:08
言語 C++14
(gcc 13.2.0 + boost 1.83.0)
結果
AC  
実行時間 3 ms / 5,000 ms
コード長 1,101 bytes
コンパイル時間 1,755 ms
コンパイル使用メモリ 178,820 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-27 22:02:34
合計ジャッジ時間 3,473 ms
ジャッジサーバーID
(参考情報)
judge13 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,376 KB
testcase_01 AC 1 ms
4,380 KB
testcase_02 AC 2 ms
4,376 KB
testcase_03 AC 1 ms
4,380 KB
testcase_04 AC 1 ms
4,376 KB
testcase_05 AC 2 ms
4,376 KB
testcase_06 AC 2 ms
4,380 KB
testcase_07 AC 2 ms
4,376 KB
testcase_08 AC 3 ms
4,380 KB
testcase_09 AC 2 ms
4,376 KB
testcase_10 AC 2 ms
4,376 KB
testcase_11 AC 2 ms
4,380 KB
testcase_12 AC 3 ms
4,380 KB
testcase_13 AC 3 ms
4,376 KB
testcase_14 AC 2 ms
4,376 KB
testcase_15 AC 2 ms
4,376 KB
testcase_16 AC 2 ms
4,380 KB
testcase_17 AC 2 ms
4,376 KB
testcase_18 AC 2 ms
4,376 KB
testcase_19 AC 2 ms
4,376 KB
testcase_20 AC 2 ms
4,376 KB
testcase_21 AC 2 ms
4,376 KB
testcase_22 AC 1 ms
4,380 KB
testcase_23 AC 2 ms
4,380 KB
testcase_24 AC 2 ms
4,376 KB
testcase_25 AC 2 ms
4,376 KB
testcase_26 AC 2 ms
4,376 KB
testcase_27 AC 3 ms
4,376 KB
testcase_28 AC 2 ms
4,380 KB
testcase_29 AC 3 ms
4,380 KB
testcase_30 AC 2 ms
4,380 KB
testcase_31 AC 2 ms
4,376 KB
testcase_32 AC 3 ms
4,376 KB
testcase_33 AC 2 ms
4,376 KB
testcase_34 AC 3 ms
4,376 KB
testcase_35 AC 2 ms
4,376 KB
testcase_36 AC 3 ms
4,380 KB
testcase_37 AC 2 ms
4,376 KB
testcase_38 AC 1 ms
4,376 KB
testcase_39 AC 2 ms
4,380 KB
testcase_40 AC 2 ms
4,376 KB
testcase_41 AC 2 ms
4,380 KB
testcase_42 AC 1 ms
4,376 KB
testcase_43 AC 2 ms
4,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

const int INF = 0x3f3f3f3f;

signed main(){
  int N, C, V; cin >> N >> C >> V;
  vector< int > S( V ), T( V ), Y( V ), M( V );
  for( int i = 0; i < V; ++i )
    cin >> S[ i ], --S[ i ];
  for( int i = 0; i < V; ++i )
    cin >> T[ i ], --T[ i ];
  for( int i = 0; i < V; ++i )
    cin >> Y[ i ];
  for( int i = 0; i < V; ++i )
    cin >> M[ i ];
  priority_queue< tuple< int, int, int >, vector< tuple< int, int, int > >, greater< tuple< int, int, int > > > pq;
  vector< vector< int > > dp( N, vector< int >( C + 1, INF ) );
  pq.emplace( dp[ 0 ][ C ] = 0, 0, C );
  while( not pq.empty() ){
    int d, u, c; tie( d, u, c ) = pq.top(); pq.pop();
    if( u == N - 1 )
      cout << d << endl, exit( 0 );
    if( d != dp[ u ][ c ] ) continue;
    for( int i = 0; i < V; ++i )
      if( u == S[ i ] and c >= Y[ i ] )
        if( dp[ T[ i ] ][ c - Y[ i ] ] > dp[ u ][ c ] + M[ i ] )
          dp[ T[ i ] ][ c - Y[ i ] ] = dp[ u ][ c ] + M[ i ],
          pq.emplace( dp[ T[ i ] ][ c - Y[ i ] ], T[ i ], c - Y[ i ] );
  }
  cout << -1 << endl;
  return 0;
}
0