제출 #981741

#제출 시각아이디문제언어결과실행 시간메모리
981741kaopjEvacuation plan (IZhO18_plan)C++14
0 / 100
247 ms42372 KiB
#include <bits/stdc++.h> using namespace std; vector<pair<int,int>> edge[100001]; int n,m; int dist[100001]; unordered_map<int,unordered_map<int,int>> dp; bool vis[100001]; int dfs(int x,int t) { vis[x]=1; if (t == x||!dist[x]) { return dist[x]; } if (dp[x][t]) { return dp[x][t]; } int maxi=0; for (auto i:edge[x]) { if (vis[i.second]) { continue; } maxi = max(maxi,dfs(i.second,t)); } return dp[x][t]=dp[t][x]=min(dist[x],maxi); } int main() { cin.tie(0)->sync_with_stdio(0); cin >> n >> m; int x,y,d; for (int i =0;i<m;i++) { cin >> x >> y >> d; edge[x].push_back({d,y}); edge[y].push_back({d,x}); } int q; cin >> q; priority_queue<pair<int,int>,vector<pair<int,int>>,greater<pair<int,int>>> pq; for (int i=1;i<=n;i++) { dist[i] = 1e9; } while (q--) { cin >> x; pq.push({0,x}); dist[x]=0; } while (!pq.empty()) { auto u = pq.top(); pq.pop(); if (dist[u.second] < u.first) { continue; } for (auto i:edge[u.second]) { if (dist[i.second] > i.first+u.first) { dist[i.second] = i.first+u.first; pq.push({dist[i.second],i.second}); } } } cin >> q; while (q--) { memset(vis,0,sizeof vis); cin >> x >> y; cout << dfs(x,y) << '\n'; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...