이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
const int N = 5000;
int nr[N];
int tree[4 * N];
void make(int i, int num, int a, int b, int node)
{
if (a == b)
{
tree[node] = num;
return;
}
int mid = (a + b) / 2;
if (i <= mid) make(i, num, a, mid, node * 2);
else make(i, num, mid + 1, b, node * 2 + 1);
tree[node] = tree[node * 2] + tree[node * 2 + 1];
}
void cons(int a, int b, int node)
{
if (a == b)
{
tree[node] = 1;
return;
}
int mid = (a + b) / 2;
cons(a, mid, node * 2);
cons(mid + 1, b, node * 2 + 1);
tree[node] = tree[node * 2] + tree[node * 2 + 1];
}
int kth(int k, int a, int b, int node)
{
if (a == b)
{
tree[node] = 0;
return a;
}
int mid = (a + b) / 2;
int ret = -1;
if (tree[node * 2] > k) ret = kth(k, a, mid, node * 2);
else ret = kth(k - tree[node * 2], mid + 1, b, node * 2 + 1);
tree[node] = tree[node * 2] + tree[node * 2 + 1];
return ret;
}
int GetBestPosition(int n, int c, int r, int *k, int *s, int *e) {
int best = -1;
int pos = -1;
//cout << endl;
for (int i = 0; i < n; i++)
{
nr[i] = r;
for (int j = 0; j < n - 1; j++)
{
if (j < i) nr[j] = k[j];
else nr[j + 1] = k[j];
}
cons(0, n - 1, 1);
int cur = 0;
for (int j = 0; j < c; j++)
{
int ci = -1;
int cbest = -1;
for (int l = s[j]; l <= e[j]; l++)
{
int ki = kth(s[j], 0, n - 1, 1);
if (nr[ki] > cbest)
{
cbest = nr[ki];
ci = ki;
}
}
make(ci, 1, 0, n - 1, 1);
if (cbest == r) cur++;
}
//cout << cur << endl;
if (cur > best)
{
best = cur;
pos = i;
}
}
return pos;
}
/*
5 3 2
1
0
4
3
0 1
0 1
1 3
*/
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |