Submission #640155

#TimeUsernameProblemLanguageResultExecution timeMemory
640155tvladm2009Easter Eggs (info1cup17_eastereggs)C++14
87 / 100
19 ms360 KiB
#include <bits/stdc++.h> #include "grader.h" using ll = long long; const int MAX_N = 512; std::vector<int> g[MAX_N + 1], v; void dfs(int u, int p = -1) { v.push_back(u); for (int v : g[u]) { if (v != p) { dfs(v, u); } } } int bsearch() { int l = 0, r = v.size() - 1, sol = -1; while (l <= r) { int mid = (l + r) / 2; std::vector<int> tmp; for (int i = 0; i <= mid; i++) { tmp.push_back(v[i]); } if (query(tmp)) { r = mid - 1; sol = mid; } else { l = mid + 1; } } return v[sol]; } int findEgg(int n, std::vector<std::pair<int, int>> bridges) { for (int i = 1; i <= n; i++) { g[i].clear(); } for (auto it : bridges) { g[it.first].push_back(it.second); g[it.second].push_back(it.first); } v.clear(); dfs(1); int answer = bsearch(); return answer; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...