제출 #920606

#제출 시각아이디문제언어결과실행 시간메모리
920606DON_FEaster Eggs (info1cup17_eastereggs)C++14
0 / 100
1 ms492 KiB
#include <bits/stdc++.h> #include "grader.h" using namespace std; using ll = long long; #define F first #define S second vector < vector < int > > g; set < int > cur, sp; vector < int > all, vis; ll p; void dfs(int u){ if ((int) sp.size() == p){ return; } vis[u] = 1; all.push_back(u); if (cur.count(u)){ sp.insert(u); } for (auto &i : g[u]){ if (!vis[i]) dfs(i); } } int findEgg (int n, vector < pair < int, int > > z){ for (int i = 1; i <= n; ++i){ cur.insert(i); } g = vector < vector < int > > (n + 1); for (int i = 0; i < n - 1; ++i){ g[z[i].F].push_back(z[i].S); } while (cur.size() > 1){ p = cur.size() / 2; for (int i = 1; i <= n; ++i){ vis = vector < int > (n + 1); dfs(i); if ((int) sp.size() == p){ break; } sp.clear(); all.clear(); } ll tmp = query(all); if (tmp){ cur.clear(); for (auto &i : sp){ cur.insert(i); } }else{ for (auto &i : sp){ cur.erase(i); } } sp.clear(); all.clear(); } if (cur.size()) return *cur.begin(); else return -1; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...