제출 #963127

#제출 시각아이디문제언어결과실행 시간메모리
963127toast12Commuter Pass (JOI18_commuter_pass)C++14
0 / 100
2084 ms37068 KiB
#include <bits/stdc++.h> using namespace std; const long long INF = 1e18; int n, m; int s, t, u, v; long long ans; long long mnu = INF, mnv = INF; vector<vector<pair<int, long long>>> adj; vector<vector<int>> p; vector<bool> visited; vector<int> path; vector<long long> dv, du; vector<bool> done; stack<int> prevu, prevv; void dijkstras(vector<vector<int>> &parent, vector<long long> &dist, int start) { priority_queue<pair<long long, int>> pq; pq.push({0, start}); while (!pq.empty()) { int x = pq.top().second; pq.pop(); if (visited[x]) continue; visited[x] = true; for (auto e : adj[x]) { long long w = e.second; if (w + dist[x] < dist[e.first]) { parent[e.first].clear(); parent[e.first].push_back(x); dist[e.first] = dist[x]+w; pq.push({-dist[e.first], e.first}); } else if (w + dist[x] == dist[e.first]) { parent[e.first].push_back(x); } } } } void find_path() { long long temp_ans = INF; if (path.back() == s) return; for (auto x : p[path.back()]) { path.push_back(x); mnu = min(mnu, du[x]); prevu.push(mnu); mnv = min(mnv, dv[x]); prevv.push(mnv); find_path(); path.pop_back(); temp_ans = min(temp_ans, mnu+mnv); prevu.pop(); prevv.pop(); mnv = prevv.top(); mnu = prevu.top(); } ans = min(ans, temp_ans); } int main() { cin >> n >> m; adj.resize(n+1); p.resize(n+1); visited.resize(n+1); cin >> s >> t >> u >> v; for (int i = 0; i < m; i++) { int x, y; long long w; cin >> x >> y >> w; adj[x].push_back({y, w}); adj[y].push_back({x, w}); } p[s].push_back(s); vector<long long> d(n+1, INF); d[s] = 0; dijkstras(p, d, s); vector<vector<int>> temp(n+1); dv.resize(n+1, INF); dv[v] = 0; fill(visited.begin(), visited.end(), false); dijkstras(temp, dv, v); du.resize(n+1, INF); du[u] = 0; fill(visited.begin(), visited.end(), false); dijkstras(temp, du, u); ans = du[v]; path.push_back(t); prevu.push(du[t]); prevv.push(dv[t]); mnu = du[t], mnv = dv[t]; find_path(); cout << ans << '\n'; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...