이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define ll long long
#define F first
#define S second
using namespace std;
struct edge{
int u, c;
ll p;
edge(int _u, int _c, ll _p) : u(_u), c(_c), p(_p) {}
};
int n, m;
vector <map <int, vector <edge>>> adj;
vector <map <int, ll>> dist, sum;
set <pair <ll, pair <int, int>>> s;
void dijkstra (){
s.insert({0, {1, 0}});
while (s.size()) {
ll d = (*s.begin()).F;
auto [v, c] = (*s.begin()).S;
s.erase(s.begin());
if (dist[v].count(c) && dist[v][c] <= d)
continue;
dist[v][c] = d;
if (!c){
for (auto Color : adj[v]) {
for (auto [u, c, p] : Color.S) {
s.insert({d + p, {u, 0}});
s.insert({d + sum[v][c] - p, {u, 0}});
s.insert({d, {u, c}});
}
}
}
else
for (auto [u, c, p] : adj[v][c])
s.insert({d + sum[v][c] - p, {u, 0}});
}
}
int32_t main() {
ios_base::sync_with_stdio(0);
cin >> n >> m;
adj.resize(n + 1);
dist.resize(n + 1);
sum.resize(n + 1);
for (ll x, y, c, z, i = 1; i <= m; i ++) {
cin >> x >> y >> c >> z;
adj[x][c].push_back(edge(y, c, z));
adj[y][c].push_back(edge(x, c, z));
sum[x][c] += z, sum[y][c] += z;
}
dijkstra();
cout << (!dist[n].count(0) ? -1 : dist[n][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... |