Submission #1189893

#TimeUsernameProblemLanguageResultExecution timeMemory
1189893comxddddddEaster Eggs (info1cup17_eastereggs)C++20
0 / 100
0 ms492 KiB
#include <bits/stdc++.h>
#include "grader.h"

using namespace std;
vector<vector<int>> g;
vector<int> o;
vector<bool> visited(513,false);
int c;

void dfs(int curr){
    o.emplace_back(curr);
    for(auto x : g[curr]){
        if(visited[x]) continue;
        visited[x] = true;
        dfs(x);
    }
}

int findEgg(int N, vector<pair<int, int>> bridges)
{
    c = 0;
    g.clear();
    g.resize(N + 1);
    for(auto x : bridges){
        g[x.first].emplace_back(x.second);
        g[x.second].emplace_back(x.first);
    }
    dfs(1);
    int l = 0, r = N - 1,ans = o[0];
    while(l < r){
        int mid = (r - l) / 2 + l;
        vector<int> ask;
        for(int i = 0; i <= mid; i++){
            ask.emplace_back(o[i]);
        }
        if(query(ask)){
            ans = o[mid];
            r = mid - 1;
        }
        else{
            l = mid + 1;
        }
    }
    return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...