Submission #952189

#TimeUsernameProblemLanguageResultExecution timeMemory
952189emad234Crocodile's Underground City (IOI11_crocodile)C++17
89 / 100
348 ms67280 KiB
#include "crocodile.h" #include <bits/stdc++.h> #define ll long long #define F first #define S second #define pii pair<int, int> const int mod = 1e9 + 7; const int mxN = 2e5 + 5; using namespace std; vector<vector<pii>> v; int dist[mxN], mn[mxN]; int travel_plan(int N, int M, int R[][2], int L[], int K, int P[]) { memset(mn, -1, sizeof mn); v.resize(N + 2); for (int i = 0; i < N; i++) { dist[i] = 1e9 + 5; } for (int i = 0; i < M; i++) { v[R[i][1]].push_back({R[i][0], L[i]}); v[R[i][0]].push_back({R[i][1], L[i]}); } priority_queue<pii, vector<pii>, greater<pii>> q; for (int i = 0; i < K; i++) { dist[P[i]] = 0; q.push({0, P[i]}); } while (q.size()) { auto u = q.top(); q.pop(); if (dist[u.S] < u.F) continue; for (auto x : v[u.S]) { if (dist[x.F] > x.S + u.F && mn[x.F] == -1) { mn[x.F] = x.S + u.F; } else if (dist[x.F] > x.S + u.F && mn[x.F] != -1) { int Mn = mn[x.F]; mn[x.F] = min(x.S + u.F, Mn); dist[x.F] = max(x.S + u.F, Mn); q.push({dist[x.F], x.F}); } } } return dist[0]; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...