結果
問題 | No.1 道のショートカット |
ユーザー | Gyuuto |
提出日時 | 2015-12-11 03:00:43 |
言語 | C++11 (gcc 13.3.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 2,876 bytes |
コンパイル時間 | 669 ms |
コンパイル使用メモリ | 90,684 KB |
実行使用メモリ | 206,944 KB |
最終ジャッジ日時 | 2024-07-08 04:17:54 |
合計ジャッジ時間 | 7,220 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,812 KB |
testcase_01 | AC | 2 ms
6,940 KB |
testcase_02 | AC | 1 ms
6,940 KB |
testcase_03 | AC | 2 ms
6,940 KB |
testcase_04 | AC | 1 ms
6,940 KB |
testcase_05 | AC | 1 ms
6,944 KB |
testcase_06 | AC | 1 ms
6,940 KB |
testcase_07 | AC | 2 ms
6,940 KB |
testcase_08 | AC | 4 ms
6,944 KB |
testcase_09 | AC | 2 ms
6,944 KB |
testcase_10 | AC | 5 ms
6,940 KB |
testcase_11 | TLE | - |
testcase_12 | -- | - |
testcase_13 | -- | - |
testcase_14 | -- | - |
testcase_15 | -- | - |
testcase_16 | -- | - |
testcase_17 | -- | - |
testcase_18 | -- | - |
testcase_19 | -- | - |
testcase_20 | -- | - |
testcase_21 | -- | - |
testcase_22 | -- | - |
testcase_23 | -- | - |
testcase_24 | -- | - |
testcase_25 | -- | - |
testcase_26 | -- | - |
testcase_27 | -- | - |
testcase_28 | -- | - |
testcase_29 | -- | - |
testcase_30 | -- | - |
testcase_31 | -- | - |
testcase_32 | -- | - |
testcase_33 | -- | - |
testcase_34 | -- | - |
testcase_35 | -- | - |
testcase_36 | -- | - |
testcase_37 | -- | - |
testcase_38 | -- | - |
testcase_39 | -- | - |
testcase_40 | -- | - |
testcase_41 | -- | - |
testcase_42 | -- | - |
testcase_43 | -- | - |
ソースコード
// Standard I/O #include <iostream> #include <sstream> #include <cstdio> // Standard Library #include <cstdlib> #include <cstring> #include <ctime> #include <cmath> // Template Class #include <complex> #include <string> #include <vector> #include <list> #include <set> #include <map> #include <queue> #include <stack> // Container Control #include <algorithm> #include <tuple> using namespace std; #define rep( i, n ) for( int i = 0; i < n; ++i ) #define irep( i, n ) for( int i = n-1; i >= 0; --i ) #define reep( i, s, n ) for ( int i = s; i < n; ++i ) #define ireep( i, n, s ) for ( int i = n-1; i >= s; --i ) #define foreach(itr, x) for( typeof(x.begin()) itr = x.begin(); itr != x.end(); ++itr) #define mp( a, b ) make_pair( a, b ) #define pb( a ) push_back( a ) #define all( v ) v.begin(), v.end() #define fs first #define sc second #define vc vector // for visualizer.html double SCALE = 1.0; double OFFSET_X = 0.0; double OFFSET_Y = 0.0; #define LINE(x,y,a,b) cerr << "line(" << SCALE*(x) + OFFSET_X << "," \ << SCALE*(y) + OFFSET_Y << "," \ << SCALE*(a) + OFFSET_X << "," \ << SCALE*(b) + OFFSET_Y << ")" << endl; #define CIRCLE(x,y,r) cerr << "circle(" << SCALE*(x) + OFFSET_X << "," \ << SCALE*(y) + OFFSET_Y << "," \ << SCALE*(r) << ")" << endl; typedef long long ll; typedef complex<double> Point; typedef pair<int, int> pii; typedef pair<int, pii> ipii; typedef vector<int> vi; typedef vector<double> vd; typedef vector< vector<int> > vii; typedef vector< vector<double> > vdd; typedef vector<int>::iterator vi_itr; const int IINF = 1 << 28; const double INF = 1e30; const double EPS = 1e-10; const double PI = acos(-1.0); // Direction : L U R D const int dx[] = { -1, 0, 1, 0}; const int dy[] = { 0, -1, 0, 1 }; struct Edge { int t, y, m; Edge(){} Edge( int t, int y, int m ) :t(t), y(y), m(m) {} }; struct Node { int p, c, y; Node(){} Node( int p, int c, int y ) :p(p), c(c), y(y) {} }; inline bool operator < ( const Node& n1, const Node& n2 ) { return (n1.y == n2.y ? n1.c > n2.c : n1.y > n2.y); } int main() { int N, C, V; vector<Edge> edge[50]; int S[1500], T[1500], Y[1500], M[1500]; cin >> N >> C >> V; rep(i, V){ cin >> S[i]; --S[i]; } rep(i, V){ cin >> T[i]; --T[i]; } rep(i, V){ cin >> Y[i]; } rep(i, V){ cin >> M[i]; } rep(i, V){ edge[S[i]].pb( Edge(T[i], Y[i], M[i]) ); } priority_queue<Node> que; que.push( Node(0, 0, 0) ); int ans = -1, d[50]; rep(i, N) d[i] = IINF; while( !que.empty() ){ Node n = que.top(); que.pop(); d[n.p] = min(d[n.p], n.y); rep(i, edge[n.p].size()){ if( n.c + edge[n.p][i].y > C ) continue; // if( n.y + edge[n.p][i].m > d[edge[n.p][i].t] ) continue; que.push( Node(edge[n.p][i].t, n.c + edge[n.p][i].y, n.y + edge[n.p][i].m ) ); } } cout << (d[N-1] == IINF ? -1 : d[N-1]) << endl; }