Submission #857418

# Submission time Handle Problem Language Result Execution time Memory
857418 2023-10-06T07:26:37 Z chilinhxyzabc Easter Eggs (info1cup17_eastereggs) C++17
87 / 100
13 ms 1264 KB
#include <bits/stdc++.h>
#define ll long long
#define infInt (int)1e9 + 1
// #define infLL 0x3f3f3f3f3f3f
#define infLL (int)1e17
#define vt vector<int>
#define vtt vector<vt>
#define vttt vector<vtt>
#define vtttt vector<vttt>
#define pii pair<int, int>
#define vpii vector<pii>
#define endl '\n'
#define all(a) a.begin(), a.end()
#define _sort(a) sort(all(a))
#define bsUp(a, x) upper_bound(all(a), x) - a.begin()
#define bsLow(a, x) lower_bound(all(a), x) - a.begin()
#define rev(a) reverse(all(a))
#define uni(vals) vals.resize(distance(vals.begin(), unique(all(vals))))
// #define int ll
// #define in(a); ; 
// #define hi ;
// #include "/home/phamngocthi/cp/see.cpp"
using namespace std;
 
vt st;
vector<vector<int>> adj(600, vector<int>());
 
void dfs(int u, int p) {
    st.push_back(u);
    for(int v : adj[u]) {
        if(v == p)
            continue;
        dfs(v, u);
    }
}
 
int query(vector<int> islands);
 
int findEgg(int N, vector<pair<int,int>> bridges) {
    for(int i = 1; i <= N; i++)
        adj[i].clear();
    for(auto[u, v] : bridges) {
        adj[u].push_back(v);
        adj[v].push_back(u);
    }
    st.clear();
    dfs(1, 0);
    int l = 0, r = N - 1, res = -1;
    while(l <= r) {
        int m = (l + r) / 2;
        vector<int> a;
        for(int i = 0; i <= m; i++)
            a.push_back(st[i]);
        if(query(a)) {
            res = st[m];
            r = m - 1;
        } else {
            l = m + 1;
        }
        a.clear();
    }
    return res;
}
 
// signed main() {
//     ios_base::sync_with_stdio(false);cin.tie(NULL);
// }
# Verdict Execution time Memory Grader output
1 Partially correct 1 ms 344 KB Number of queries: 5
2 Partially correct 0 ms 344 KB Number of queries: 5
3 Partially correct 0 ms 596 KB Number of queries: 5
4 Partially correct 0 ms 344 KB Number of queries: 5
# Verdict Execution time Memory Grader output
1 Correct 3 ms 472 KB Number of queries: 9
2 Correct 9 ms 748 KB Number of queries: 9
3 Correct 12 ms 992 KB Number of queries: 9
4 Correct 12 ms 740 KB Number of queries: 9
# Verdict Execution time Memory Grader output
1 Partially correct 13 ms 1264 KB Number of queries: 10
2 Correct 9 ms 992 KB Number of queries: 9
3 Partially correct 10 ms 1248 KB Number of queries: 10
4 Partially correct 10 ms 488 KB Number of queries: 10