# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
61573 | Flying_dragon_02 | Easter Eggs (info1cup17_eastereggs) | C++17 | 100 ms | 820 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "grader.h"
using namespace std;
#define fi first
#define se second
#define pb push_back
#define mp make_pair
typedef pair<int, int> ii;
vector<int> graph[600];
int child[600], m, root, par[600], ok = 0;
bool vis1[600], vis2[600];
vector<int> ask;
void solve(int u, int p){
vis2[u] = 1;
ask.pb(u);
for(int i = 0; i < graph[u].size(); i++){
int v = graph[u][i];
if(v == p) continue;
solve(v, u);
}
}
void dfs(int u){
vis1[u] = 1;
child[u] = 1;
for(int i = 0; i < graph[u].size(); i++){
int v = graph[u][i];
if(vis2[v] == 0 && vis1[v] == 0){
dfs(v);
par[v] = u;
child[u] += child[v];
}
}
if(child[u] == m / 2 && ok == 0){
solve(u, par[u]);
ok = 1;
}
}
int findEgg(int N, vector<ii> bridges){
for(int i = 0; i < bridges.size(); i++){
int u = bridges[i].fi, v = bridges[i].se;
graph[u].pb(v); graph[v].pb(u);
}
int m = N;
while(m != 1){
ask.clear();
ok = 0;
for(int i = 1; i <= N; i++){
if(vis2[i] == 0){
memset(vis1, 0, sizeof(vis1));
dfs(i);
if(ask.size() > 0){
if(query(ask) == 0){
bool vis3[N];
for(int i = 0; i < ask.size(); i++){
vis3[ask[i]] = 1;
vis2[ask[i]] = 0;
}
for(int i = 1; i <= N; i++){
if(vis3[i] == 0 && vis2[i] == 0)
vis2[i] = 1;
}
break;
}
}
}
}
m = m / 2;
}
ask.clear();
for(int i = 1; i <= N; i++){
if(vis2[i] == 0){
ask.pb(i);
query(ask);
return 0;
}
}
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |