Submission #629765

#TimeUsernameProblemLanguageResultExecution timeMemory
629765hltkRarest Insects (IOI22_insects)C++17
59.03 / 100
171 ms456 KiB
#include "insects.h" #include <vector> using namespace std; int min_cardinality(int n) { vector<int> avail; int inside = 0, types = 0; for (int i = 0; i < n; ++i) { move_inside(i), inside++; if (press_button() == 1) { types++; } else { avail.push_back(i); move_outside(i), inside--; } } if (types == 1 || types == n) { return 1 ^ n ^ types; } int l = 1, r = n / 2; while (l < r) { int m = (l + r) / 2, k = m + 1; vector<int> vin, vout; for (int i : avail) { move_inside(i), inside++; if (press_button() > k) { move_outside(i), inside--; vout.push_back(i); } else { vin.push_back(i); } } if (inside < k * types) { for (int u : vin) { move_outside(u), inside--; } avail = vin; r = m; } else { avail = vout; l = m + 1; } } return l; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...