結果
| 問題 |
No.1 道のショートカット
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-06-18 00:21:24 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 987 bytes |
| コンパイル時間 | 1,974 ms |
| コンパイル使用メモリ | 180,636 KB |
| 実行使用メモリ | 814,380 KB |
| 最終ジャッジ日時 | 2024-06-25 13:17:41 |
| 合計ジャッジ時間 | 4,936 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 7 MLE * 1 -- * 32 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
#define rep(i, n) for(int i=0; i<n; i++)
#define debug 0
using ll = long long;
using ld = long double;
const int mod = 998244353;
#include <time.h>
#include <chrono>
int main() {
int N, C, V;
cin >> N >> C >> V;
vector<vector<int>> path(N);
vector<int> S(V), T(V), Y(V), M(V);
rep(i, 4) {
rep(j, V) {
if (i == 0) {
cin >> S[j];
S[j]--;
path[S[j]].push_back(j);
}
if (i == 1) {
cin >> T[j];
T[j]--;
}
if (i == 2) {
cin >> Y[j];
}
if (i == 3) {
cin >> M[j];
}
}
}
vector<vector<pair< int, int>>> ans(N);
ans[0].push_back({ 0,0 });
rep(i, N - 1) {
for (int x : path[i]) {
for (pair<int,int>p : ans[i]) {
if (p.second + Y[x] <= C) {
ans[T[x]].push_back({ p.first + M[x],p.second + Y[x] });
}
}
}
}
if (ans[N - 1].empty()) {
cout << -1 << endl;
}
else {
sort(ans[N - 1].begin(), ans[N - 1].end());
cout << ans[N - 1][0].first << endl;
}
}