제출 #1050101

#제출 시각아이디문제언어결과실행 시간메모리
1050101vjudge1Commuter Pass (JOI18_commuter_pass)C++17
15 / 100
238 ms25700 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]; vector<pair<ll,ll>> a[maxn]; set<pair<ll,ll>> ro; 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(ro.count(make_pair(cur,to))){ cost=0; } if(ans[cur]+cost<ans[to]){ ans[to]=ans[cur]+cost; p[to]=cur; q.push(make_pair(-ans[to],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]; } } void cl_ans(ll v){ for(int i=1;i<=n;i++)ans[i]=inf; ans[v]=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; cl_ans(s1); dfs_dj(s1); 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...