Submission #1050172

#TimeUsernameProblemLanguageResultExecution timeMemory
1050172vjudge1Commuter Pass (JOI18_commuter_pass)C++17
0 / 100
680 ms262144 KiB
#include<algorithm> #include<iostream> #include<vector> #include<queue> #include<set> using namespace std; #define ll long long const ll maxn=100001; const ll inf=999999999999999999; ll n,m,s1,f1,s2,f2,ans[maxn],p[maxn]; bool was[maxn]; vector<pair<ll,ll>> a[maxn]; set<pair<ll,ll>> ro; vector<ll> vp[maxn]; bool change_p=1; void dfs_dj(ll v){ priority_queue<pair<ll,ll>> q; q.push(make_pair(0,v)); while(!q.empty()){ ll cur_ans=-q.top().first,cur=q.top().second; q.pop(); if(ans[cur]!=cur_ans)continue; for(ll i=0;i<int(a[cur].size());i++){ ll to=a[cur][i].first,cost=a[cur][i].second; if(p[cur]==to)continue; if(ro.count(make_pair(cur,to))){ cost=0; } if(ans[cur]+cost<=ans[to]){ if(ans[to]>ans[cur]+cost and change_p){ vp[to].clear(); } ans[to]=ans[cur]+cost; if(change_p){ vp[to].push_back(cur); p[to]=cur; } q.push(make_pair(-ans[to],to)); } } } } void cl_ans(ll v){ for(int i=1;i<=n;i++)ans[i]=inf; ans[v]=0; } void go(ll v){ cl_ans(v); dfs_dj(v); } ll final_ans=inf; void set_was(ll v){ change_p=false; was[v]=1; go(v); final_ans=min(final_ans,ans[f2]); for(ll i=0;i<int(vp[v].size());i++){ ll to=vp[v][i]; if(!was[to]){ set_was(to); } } } void set_route(ll v){ ro.clear(); while(p[v]!=v){ ro.insert(make_pair(p[v],v)); ro.insert(make_pair(v,p[v])); v=p[v]; } } bool check_uniq(ll cur){ if(p[cur]==cur)return true; if(vp[cur].size()>1)return false; return check_uniq(vp[cur][0]); } int main(){ cin>>n>>m>>s1>>f1>>s2>>f2; ll st,ft,c; for(int i=0;i<m;i++){ cin>>st>>ft>>c; a[st].push_back(make_pair(ft,c)); a[ft].push_back(make_pair(st,c)); } p[s1]=s1; go(s1); bool uniq_route=check_uniq(f1); if(n<=301 and !uniq_route){ final_ans=inf; set_was(f1); cout<<final_ans; }else{ set_route(f1); cl_ans(s2); dfs_dj(s2); cout<<ans[f2]; } 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...