제출 #562653

#제출 시각아이디문제언어결과실행 시간메모리
562653Iwanttobreakfree악어의 지하 도시 (IOI11_crocodile)C++98
0 / 100
1 ms340 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)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; } /*int main(){ int n,m,k; cin>>n>>m>>k; int R[m][2],l[m],e[k]; for(int i=0;i<m;i++)cin>>R[i][0]>>R[i][1]>>l[i]; for(int i=0;i<k;i++)cin>>e[i]; cout<<travel_plan(n,m,R,l,k,e); }*/
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...