This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
///
/// What would happen if we used assembly language for CP?
/// Sorry, that was a strange thing to ask.
///
#include <bits/stdc++.h>
#define Loop(x,l,r) for(ll x = ll(l); x < ll(r); ++x)
#define LoopR(x,l,r) for(ll x = ll(r)-1; x >= ll(l); --x)
#define Kill(x) exit((cout << (x) << '\n', 0))
typedef long long ll;
typedef std::pair<int,int> pii;
typedef std::pair<ll,ll> pll;
using namespace std;
const int N = 200'010;
const int lg = 20;
vector<pii> A[N];
vector<int> B[N];
int dis[N];
pii srt[N];
int n, m, k;
int par[N];
int rt(int v){return par[v]==-1?v:(par[v]=rt(par[v]));}
namespace rmq{
vector<int> vec;
int ti[N];
void dfs(int v){
ti[v] = vec.size();
vec.push_back(dis[v]);
for(int u : B[v]){
dfs(u);
vec.push_back(dis[v]);
}
}
int a[lg][N];
int n;
void make(){
n = vec.size();
Loop(i,0,n) a[0][i] = vec[i];
Loop(k,0,lg-1)
for(int i = 0; i+(2<<k) <= n; ++i)
a[k+1][i] = min(a[k][i], a[k][i+(1<<k)]);
}
int get(int l, int r){
int k = __lg(r-l);
return min(a[k][l], a[k][r-(1<<k)]);
}
}
int main()
{
cin.tie(0) -> sync_with_stdio(false);
Loop(i,0,N) dis[i] = 1e9;
Loop(i,0,N) par[i] = -1;
cin >> n >> m;
Loop(i,0,m){
int v, u, w;
cin >> v >> u >> w;
--v; --u;
A[v].push_back({u,w});
A[u].push_back({v,w});
}
cin >> k;
set<pii> q;
Loop(i,0,k) {
int v; cin >> v; --v;
dis[v] = 0;
q.emplace(0, v);
}
while(q.size()){
auto [d, v] = *q.begin(); q.erase(q.begin());
for(auto [u, w] : A[v]){
if(d+w < dis[u]){
q.erase({dis[u],u});
dis[u] = d+w;
q.insert({dis[u],u});
}
}
}
Loop(i,0,n) srt[i] = {dis[i],i};
sort(srt,srt+n,greater<pii>());
Loop(i,0,n){
int v = srt[i].second;
for(auto [u, w] : A[v]){
if(dis[u] > dis[v] || (dis[u]==dis[v] && u>v)){
//cout<<v<<' '<<u<<"!"<<endl;
u = rt(u);
if(u!=v){
par[u] = v;
B[v].push_back(u);
}
}
}
}
rmq::dfs(rt(0));
rmq::make();
int qq;
cin >> qq;
while(qq--){
int v, u;
cin >> v >> u;
--v; --u;
if(rmq::ti[v] > rmq::ti[u]) swap(v, u);
cout << rmq::get(rmq::ti[v], rmq::ti[u]+1) << '\n';
}
}
# | 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... |