# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
851399 | mychecksedad | Cyberland (APIO23_cyberland) | C++17 | 1044 ms | 2097152 KiB |
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 "cyberland.h"
#include<bits/stdc++.h>
using namespace std;
#define ll long long int
#define pb push_back
#define all(x) x.begin(), x.end()
const int SZ = 2e5;
int _H;
double po[35];
vector<pair<int, double>> g[SZ];
vector<bool> VIS;
void dfs(int v, int p){
VIS[v] = 1;
for(auto U: g[v]){
int u = U.first;
if(!VIS[u] && u != _H)
dfs(u, v);
}
}
double solve(int N, int M, int K, int H, std::vector<int> x, std::vector<int> y, std::vector<int> c, std::vector<int> arr) {
for(int i = 0; i < N; ++i) g[i].clear();
_H = H;
VIS.clear();
VIS.resize(N);
po[0] = 1;
for(int i = 1; i < 35; ++i) po[i] = po[i - 1] * 2;
vector<vector<double>> dist(N);
vector<vector<bool>> vis(N);
for(int i = 0; i < M; ++i)
g[x[i]].pb({y[i], c[i]}),
g[y[i]].pb({x[i], c[i]});
for(int i = 0; i < N; ++i) dist[i].resize(K + 1, -1), vis[i].resize(K + 1);
dist[H][0] = 0;
set<array<double, 3>> Q;
Q.insert({0, H, 0});
while(!Q.empty()){
auto it = *Q.begin();
int v = it[1], k = it[2];
Q.erase(Q.begin());
if(vis[v][k]) continue;
vis[v][k] = 1;
for(auto U: g[v]){
int u = U.first;
if(u == H) continue;
double w = U.second;
if(arr[v] == 2 && k + 1 <= K && (dist[u][k + 1] == -1 || dist[u][k + 1] > dist[v][k] + w / po[k + 1])){
Q.erase({dist[u][k + 1], u, k + 1});
dist[u][k + 1] = dist[v][k] + w / po[k + 1];
Q.insert({dist[u][k + 1], u, k + 1});
}
if(dist[u][k] == -1 || dist[u][k] > dist[v][k] + w / po[k]){
Q.erase({dist[u][k], u, k});
dist[u][k] = dist[v][k] + w / po[k];
Q.insert({dist[u][k], u, k});
}
}
}
if(!vis[0][0]) return -1;
double ans = -1;
dfs(0, 0);
for(int i = 0; i < N; ++i){
if(VIS[i] && (arr[i] == 0 || i == 0)){
for(int j = 0; j <= K; ++j){
if(dist[i][j] == -1) continue;
ans = ans == -1 || ans > dist[i][j] ? dist[i][j] : ans;
}
}
}
return ans;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |