이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
using vi = vector<int>;
using ii = pair<int, int>;
using vvii = vector<vector<ii>>;
#define INF 1000000000
int main() {
int K, n, m, o; cin >> K >> n >> m >> o;
vvii rev(n);
for (int i = 0; i < m; ++i) {
int a, b, t; cin >> a >> b >> t;
rev[b].emplace_back(t, a);
}
vi dist(n, INF);
dist[0] = 0;
for (int u = 1; u < n; ++u) {
for (ii e : rev[u]) {
dist[u] = min(dist[u], dist[e.second] + e.first);
}
}
for (int i = 0; i < o; ++i) {
int a, b; cin >> a >> b;
assert(a == 0);
int ans = dist[b];
cout << (ans == INF ? -1 : ans) << endl;
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |