# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
805734 | caganyanmaz | 드문 곤충 (IOI22_insects) | C++17 | 117 ms | 444 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "insects.h"
#define pb push_back
#define pp pop_back
using namespace std;
constexpr static int MXSIZE = 2000;
constexpr static int BLOCK = 40;
set<int> b;
int bv[MXSIZE];
int n;
bool check(int count)
{
vector<int> inserted;
for (int i = 0; i < n; i++)
{
if (b.find(i) != b.end())
continue;
move_inside(i);
inserted.pb(i);
if (press_button() > count)
{
inserted.pp();
move_outside(i);
}
}
bool res = inserted.size() + b.size() == (b.size() * count);
for (int i : inserted)
move_outside(i);
return res;
}
int find_by_count()
{
int l = 1, r = 1 + (n / b.size());
while (r - l > 1)
{
int m = l+r>>1;
if (check(m))
l = m;
else
r = m;
}
return l;
}
int find_by_element(int l, int r, vector<int> v)
{
if (r - l == 1)
{
move_outside(bv[l]);
return v.size()+1;
}
int m = l+r>>1;
for (int i = m; i < r; i++)
move_outside(bv[i]);
vector<int> lv, rv;
for (int i : v)
{
move_inside(i);
if (press_button() > 1)
lv.pb(i);
else
rv.pb(i);
move_outside(i);
}
int lres = find_by_element(l, m, lv);
for (int i = m; i < r; i++)
move_inside(bv[i]);
int rres = find_by_element(m, r, rv);
return min(lres, rres);
}
int find_by_element()
{
int i = 0;
for (int j : b)
bv[i++] = j;
vector<int> v;
for (int i = 0; i < n; i++)
if (b.find(i) == b.end())
v.pb(i);
return find_by_element(0, b.size(), v);
}
int min_cardinality(int N)
{
n = N;
for (int i = 0; i < n; i++)
{
move_inside(i);
if (press_button() == 1)
b.insert(i);
else
move_outside(i);
}
if (b.size() > BLOCK)
return find_by_count();
else
return find_by_element();
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |