# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1017846 | DorostWef | Teams (IOI15_teams) | C++17 | 1464 ms | 319212 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "teams.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair <int, int> pii;
#define F first
#define S second
const int MXN = 500005, SegN = (1 << 20), LG = 19;
pii a[MXN];
int n;
vector <int> seg[SegN];
vector <int> seg2[SegN];
bool f[SegN];
int e[SegN], ans[SegN];
vector <int> vv;
int cnt (int v, int x) {
if (seg[v].empty())
return 0;
return (upper_bound (seg[v].begin(), seg[v].end(), x)) - (upper_bound (seg[v].begin(), seg[v].end(), e[v])) - ans[v];
}
void shift (int v) {
vv.push_back(v);
vv.push_back(v * 2);
vv.push_back(v * 2 + 1);
if (e[v] >= e[v * 2]) {
e[v * 2] = e[v];
ans[v * 2] = 0;
}
if (e[v] >= e[v * 2 + 1]) {
e[v * 2 + 1] = e[v];
ans[v * 2 + 1] = 0;
}
}
int find (int x) {
int k = x;
int v = (1 << 19) + (lower_bound (a, a + n, make_pair(x, 0)) - a);
while (true) {
while (v % 2 == 0)
v /= 2;
vector <int> wef;
int few = v;
while (few > 1) {
few /= 2;
wef.push_back(few);
}
reverse(wef.begin(), wef.end());
for (int ff : wef)
shift (ff);
int w = cnt(v, x);
if (w >= k) {
break;
} else {
if (f[v]) {
return MXN;
}
e[v] = x;
ans[v] = 0;
for (int ff : wef) {
ans[ff] += w;
}
k -= w;
v /= 2;
++v;
}
}
while (v < (1 << LG)) {
shift (v);
int w = (cnt (v * 2, x));
vector <int> wef;
int few = v;
while (few > 1) {
few /= 2;
wef.push_back(few);
}
if (w >= k) {
v *= 2;
} else {
v *= 2;
e[v] = x;
for (int ff : wef)
ans[ff] += w;
v++;
k -= w;
}
}
vector <int> wef;
int few = v;
while (few > 1) {
few /= 2;
wef.push_back(few);
}
int w = 1;
e[v] = x;
for (int ff : wef)
ans[ff] += w;
return (v - (1 << LG));
}
void init(int N, int A[], int B[]) {
for (int i = 0; i <= 20; i++) {
f[(1 << i) - 1] = true;
}
n = N;
for (int i = 0; i < n; i++) {
a[i].F = B[i];
a[i].S = A[i];
}
sort (a, a + n);
for (int i = SegN - 1; i >= 0; i--) {
if (i >= (1 << LG)) {
if ((i - (1 << LG)) < n) {
seg[i] = {a[i - (1 << LG)].S};
}
} else {
merge (seg[i << 1].begin(), seg[i << 1].end(), seg[i << 1 | 1].begin(), seg[i << 1 | 1].end(), back_inserter(seg[i]));
}
seg2[i] = seg[i];
}
}
int can(int M, int K[]) {
vv.clear();
sort (K, K + M);
bool h = true;
int st = 0;
for (int i = 0; i < M; i++) {
st = find (K[i]);
if (st > n)
h = false;
else if (a[st].F < K[i])
h = false;
}
for (int v : vv) {
e[v] = 0;
ans[v] = 0;
}
return h;
}
Compilation message (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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |