This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "crocodile.h"
#include <bits/stdc++.h>
#define fi first
#define se second
using namespace std;
typedef long long LL;
typedef pair<LL, LL> pll;
struct Edge{
int v;LL w;
Edge(){}
Edge(int v, LL w): v(v), w(w) {}
bool operator< (const Edge &rhs) const{
return w > rhs.w;
}
};
const int mxsz = 1e5 + 3;
int n, m, k;
vector<Edge> adj[mxsz];
LL d[mxsz];
pll best[mxsz];
priority_queue<Edge> pq;
int travel_plan(int N, int M, int R[][2], int L[], int K, int P[]) {
n = N, m = M, k = K;
fill(best, best+n, make_pair(1e18, 1e18));
for (int i = 0, u, v; i < m; i++){
u = R[i][0], v = R[i][1];
adj[u].emplace_back(v, L[i]);
adj[v].emplace_back(u, L[i]);
}
for (int i = 0; i < k; i++) pq.emplace(P[i], 0);
for (int i = 0; i < k; i++) best[P[i]] = make_pair(0,0);
while (!pq.empty()){
Edge e = pq.top(); pq.pop();
int u = e.v;
//cout << u << ' ' << e.w << " {" << best[u].fi << ", " << best[u].se << '}'<< '\n';
// if (e.w < best[u].se) best[u].se = e.w;
// if (best[u].fi > best[u].se) swap(best[u].fi, best[u].se);
if (best[u].se < e.w) continue;
int v; LL w;
for (Edge nx : adj[u]){
v = nx.v, w = nx.w; LL c = e.w + w;
//if (best[u].se > c){ swap(best[u].se, c); }
if (best[v].fi > c){
if (best[v].se > best[v].fi){
pq.emplace(v, best[v].fi);
}
swap(best[v].fi, best[v].se);
best[v].fi = c;
} else if (best[v].se > c){
pq.emplace(v, (best[v].se = c) );
}
}
}
LL ret = best[0].se;
return (ret >= 1e18 ? -1 : ret);
return n;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |