Submission #582134

#TimeUsernameProblemLanguageResultExecution timeMemory
582134VanillaHighway Tolls (IOI18_highway)C++17
0 / 100
258 ms262144 KiB
#include <bits/stdc++.h> #include "highway.h" typedef long long int64; using namespace std; const int maxn = 9e4 + 2; const int maxm = 13e4 + 2; vector <int> ad [maxn]; vector <int> ord; int N, M; // int64 query (int x) { // vector <int> w (M, 0); // for (int i = 0; i <= x; i++){ // w[i] = 1; // } // return ask(w); // } void dfs (int u, int p) { ord.push_back(u); for (int v: ad[u]) { if (v == p) continue; dfs(v, u); } } void find_pair(int n, vector<int> u, vector<int> v, int a, int b) { int m = u.size(); N = n; M = m; for (int i = 0; i < m; i++){ ad[u[i]].push_back(v[i]); ad[v[i]].push_back(u[i]); } vector <int> w (m, 1); int64 tg = ask(w); cout << tg << "\n"; int len = tg / b; dfs(0, -1); answer(0, ord[len]); // int l = 0, r = m - 1, rs = -1; // while (l <= r) { // int mid = (l + r) / 2; // cout << mid << " " << query(mid) << "\n"; // if (query(mid) >= tg) { // rs = mid; // r = mid - 1; // } // else { // l = mid + 1; // } // } // answer(0, rs); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...