Submission #922048

#TimeUsernameProblemLanguageResultExecution timeMemory
922048IanisEaster Eggs (info1cup17_eastereggs)C++17
81 / 100
28 ms1252 KiB
#include <bits/stdc++.h> #include "grader.h" using namespace std; using pii = pair<int, int>; int my_query(const set<int> &s) { vector<int> v; for (auto &it : s) v.push_back(it); return query(v); } int findEgg(int n, vector<pii> bridges) { vector<vector<int>> g(n + 1); vector<bool> vis(n + 1); vector<int> euler; for (auto [ x, y ] : bridges) { g[x].push_back(y); g[y].push_back(x); } function<void(int)> dfs = [&](int x) { vis[x] = true; euler.push_back(x); for (auto u : g[x]) { if (!vis[u]) { dfs(u); euler.push_back(x); } } }; dfs(1); function<bool(int)> check = [&](int mid) { set<int> s; for (int i = 0; i < mid; i++) s.insert(euler[i]); return !my_query(s); }; int l = 1, r = int(euler.size()); while (l <= r) { int mid = (l + r) >> 1; if (check(mid)) l = mid + 1; else r = mid - 1; } return euler[r]; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...