Submission #745026

#TimeUsernameProblemLanguageResultExecution timeMemory
745026math_rabbit_1028Rarest Insects (IOI22_insects)C++17
96.93 / 100
82 ms416 KiB
#include "insects.h" #include <bits/stdc++.h> using namespace std; int types = 0, ch[2020], use[2020], cnt = 0; int min_cardinality(int N) { // calculate types: N times for (int i = 0; i < N; i++) { move_inside(i); if (press_button() >= 2) move_outside(i); else { ch[i] = 1; types++; cnt++; use[i] = 1; } } int st = 1, ed = N / types; bool add = true; while (st < ed) { int x = (st + ed + 1) / 2; if (add) { for (int i = 0; i < N; i++) { if (ch[i] == 1) continue; if (use[i] == 1) continue; move_inside(i); if (press_button() > x) move_outside(i); else { use[i] = 1; cnt++; } } } else { for (int i = N - 1; i >= 0; i--) { if (ch[i] == 1) continue; if (use[i] == 0) continue; move_outside(i); if (press_button() < x) move_inside(i); else { use[i] = 0; cnt--; } } for (int i = 0; i < N; i++) { if (ch[i] == 1) continue; if (use[i] == 1) continue; move_inside(i); if (press_button() > x) move_outside(i); else { use[i] = 1; cnt++; } } } if (cnt == x * types) { st = x; add = true; for (int i = 0; i < N; i++) if (use[i] == 1) ch[i] = 1; } else { ed = x - 1; add = false; for (int i = 0; i < N; i++) if (use[i] == 0) ch[i] = 1; } } return st; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...