Submission #562654

#TimeUsernameProblemLanguageResultExecution timeMemory
562654IwanttobreakfreeCrocodile's Underground City (IOI11_crocodile)C++98
100 / 100
556 ms77080 KiB
#include <iostream> #include <vector> #include <queue> #include "crocodile.h" using namespace std; typedef long long ll; int travel_plan(int N, int M, int R[][2], int L[], int K, int P[]){ vector<pair<ll,ll>> d(N,{1e18,1e18}); vector<bool> seen(N,false); vector<vector<pair<int,ll>>> g(N,vector<pair<int,ll>>()); for(int i=0;i<M;i++){ g[R[i][0]].push_back({R[i][1],L[i]}); g[R[i][1]].push_back({R[i][0],L[i]}); } priority_queue<pair<ll,int>> pq; for(int i=0;i<K;i++){ pq.push({0,P[i]}); //seen[P[i]]=true; d[P[i]].first=d[P[i]].second=0; } while(!pq.empty()){ ll dist=-pq.top().first,u=pq.top().second; pq.pop(); //cout<<u<<' '; if(dist!=d[u].second||seen[u])continue; seen[u]=true; for(auto v:g[u]){ if(seen[v.first])continue; if(dist+v.second<d[v.first].first){ d[v.first].second=d[v.first].first; d[v.first].first=dist+v.second; if(d[v.first].first!=d[v.first].second)pq.push({-d[v.first].second,v.first}); } else if(dist+v.second<d[v.first].second){ d[v.first].second=dist+v.second; pq.push({-d[v.first].second,v.first}); } } } return d[0].second; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...