이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define int long long
void dijkstra(ll n, ll a, vector<vector<pair<ll,ll>>> &graph, vector<ll> &from) {
priority_queue<pair<ll,ll>, vector<pair<ll,ll>>, greater<pair<ll,ll>>> pq;
vector<bool> solved(n);
for (int i=0;i<n;i++) {
if (i == a) {
pq.push(make_pair(0, i));
} else {
pq.push(make_pair(INT64_MAX, i));
}
solved[i] = false;
from[i] = INT64_MAX;
}
from[a] = 0;
pair<ll,ll> node;
while (pq.size() > 0) {
node = pq.top(); pq.pop();
if (solved[node.second]) {
continue;
}
solved[node.second] = true;
for (pair<ll,ll> i: graph[node.second]) {
if (!solved[i.first]) {
if (from[i.first] > from[node.second] + i.second) {
from[i.first] = from[node.second] + i.second;
pq.push(make_pair(from[i.first], i.first));
}
}
}
}
}
int32_t main() {
ll n, m, s, t, u, v; cin >> n >> m >> s >> t >> u >> v;
ll a, b, c;
s--; t-- ; u--; v--;
vector<ll> froms(n), fromt(n), fromu(n), fromv(n);
priority_queue<pair<ll,ll>> pq;
vector<vector<pair<ll,ll>>> graph(n);
for (int i=0;i<m;i++) {
cin >> a >> b >> c;
graph[a-1].push_back(make_pair(b-1, c));
graph[b-1].push_back(make_pair(a-1, c));
}
dijkstra(n, s, graph, froms);
dijkstra(n, t, graph, fromt);
dijkstra(n, u, graph, fromu);
dijkstra(n, v, graph, fromv);
ll mindis = froms[t];
vector<pair<ll,ll>> goodnodes;
vector<bool> visitedfor(n), visitedret(n), visited(n);
for (int i=0;i<n;i++) {
if (froms[i] + fromt[i] == mindis) {
goodnodes.push_back(make_pair(fromu[i], i));
}
visitedfor[i] = false;
visitedret[i] = false;
visited[i] = false;
}
sort(goodnodes.begin(),goodnodes.end());
vector<pair<ll,ll>> stac;
vector<ll> dpuforward(n, INT64_MAX), dpureturn(n, INT64_MAX), tracker;
pair<ll,ll> node;
for (pair<ll,ll> i: goodnodes) {
//cout << i.first << ' ' << i.second << '\n';
if (visited[i.second]) {
continue;
}
tracker.clear();
dpuforward[i.second] = i.first; dpureturn[i.second] = i.first;
visited[i.second] = true;
stac.clear(); stac.push_back(make_pair(i.second, 0));
while (stac.size() > 0) {
node = stac.back(); stac.pop_back();
for (pair<ll,ll> j: graph[node.first]) {
if (visited[j.first]) {
continue;
}
if (froms[j.first] + j.second + fromt[node.first] == mindis) {
if (node.second < 1 && !visitedret[j.first]) {
if (j.first != s || j.first != t) {
stac.push_back(make_pair(j.first, -1));
}
dpureturn[j.first] = i.first;
visitedret[j.first] = true;
tracker.push_back(j.first);
}
} if (fromt[j.first] + j.second + froms[node.first] == mindis) {
if (node.second > -1 && !visitedfor[j.first]) {
if (j.first != s || j.first != t) {
stac.push_back(make_pair(j.first, 1));
}
dpuforward[j.first] = i.first;
visitedfor[j.first] = true;
tracker.push_back(j.first);
}
}
}
}
for (ll i: tracker) {
visited[i] = true;
}
}
ll ans = fromv[u];
for (pair<ll,ll> i: goodnodes) {
ans = min(ans, fromv[i.second] + min(dpuforward[i.second], dpureturn[i.second]));
}
if (mindis == 0) {
cout << 1/0;
}
cout << ans;
}
컴파일 시 표준 에러 (stderr) 메시지
commuter_pass.cpp: In function 'int32_t main()':
commuter_pass.cpp:122:18: warning: division by zero [-Wdiv-by-zero]
122 | cout << 1/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... |