제출 #1130457

#제출 시각아이디문제언어결과실행 시간메모리
1130457akzytr경주 (Race) (IOI11_race)C++17
0 / 100
5 ms5696 KiB
#include <bits/stdc++.h> #define ve vector #define ar array #define pb push_back #define ins insert #define endl '\n' #define ll long long using namespace std; const int MXN = 2e5+5; ve<pair<int, ll>> adj[MXN]; ve<bool> proc(MXN, false); ve<int> sz(MXN, 0); int K; int szdfs(int x, int p){ sz[x] = 1; for(auto [i, _] : adj[x]){ if(i != p && !proc[i]){ szdfs(i, x); sz[x] += sz[i]; } } return sz[x]; } int find_centroid(int x, int n, int p){ for(auto [i, _] : adj[x]){ if(!proc[i] && i != p && sz[i] > n/2){ return find_centroid(i, n, x); } } return x; } int ans = 1e9; void upddfs(int x, int p, int cur, int down, map<int,int> &bk){ if(bk.count(cur)){ bk[cur] = min(bk[cur], down); } else{ bk[cur] = down; } for(auto [i, c] : adj[x]){ if(i != p && !proc[i] && cur + c <= K){ upddfs(i, x, cur + c, down+1, bk); } } } void chkdfs(int x, int p, int cur, int down, map<int, int> &bk){ if(bk.count(K-cur)){ ans = min(ans, down + bk[K-cur]); } for(auto [i, c] : adj[x]){ if(i != p && !proc[i] && cur + c <= K){ chkdfs(i, x, cur + c, down+1, bk); } } } void decompo(int x){ map<int, int> bk; int cent = find_centroid(x, szdfs(x, -1), -1); for(auto [i, c] : adj[cent]){ if(!proc[i]){ upddfs(i, cent, c, 1, bk); chkdfs(i, cent, c, 1, bk); } } proc[cent] = 1; for(auto [i, _] : adj[cent]){ if(proc[i]){continue;} decompo(i); } } int best_path(int N, int k, int H[][2], int L[]){ K = k; for(int i = 0; i < N-1; i++){ adj[H[i][0]].pb({H[i][1], L[i]}); adj[H[i][1]].pb({H[i][0], L[i]}); } szdfs(0, -1); decompo(0); if(ans == 1e9){ ans = -1; } return ans; } // int main(){ // int N, k; // cin >> N >> k; // int H[N-1][2]; // int L[N-1]; // for(int i = 0; i < N-1; i++){ // cin >> H[i][0] >> H[i][1] >> L[i]; // } // cout << best_path(N, k, H, L)<<endl; // }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...