Submission #1168869

#TimeUsernameProblemLanguageResultExecution timeMemory
1168869SmuggingSpunRarest Insects (IOI22_insects)C++20
0 / 100
15 ms464 KiB
#include<bits/stdc++.h>
#include "insects.h"
using namespace std;
template<class T>void minimize(T& a, T b){
    if(a > b){
        a = b;
    }
}
int min_cardinality(int n){
    set<int>d, s;
    for(int i = 0; i < n; i++){
        move_inside(i);
        if(press_button() == 2){
            move_outside(i);
            s.insert(i);
        }
        else{
            d.insert(i);
        }
    }
    int cnt_d = d.size(), low = 1, high = n / cnt_d, ans;
    while(low <= high){
        int mid = (low + high) >> 1;
        vector<int>add, sub;
        for(const int& i : s){
            move_inside(i);
            if(press_button() > mid){
                move_outside(i);
                sub.emplace_back(i);
            }
            else{
                add.emplace_back(i);
                d.insert(i);
            }
        }
        if(d.size() == mid * cnt_d){
            for(int& x : add){
                s.erase(x);
            }
            low = (ans = mid) + 1;
        }
        else{
            for(int& x : add){
                d.erase(x);
            }
            for(int& x : sub){
                s.erase(x);
            }
            high = mid - 1;
        }
    }
    return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...