#include <bits/stdc++.h>
#define ll long long
#define pb push_back
#define mp make_pair
using namespace std;
const int maxn = 100100;
pair<int,int> intervals[maxn];
int lc[maxn], rc[maxn], n, r, q;
int bit[maxn], curr_intv[maxn], parent[maxn];
int pref[maxn], answ[maxn];
void update(int index, int val) {
for(int i=index;i<=n;i+=i&(-i)) {
bit[i] += val;
}
}
int query(int x) {
int sum = 0;
for(int i=x;i>0;i-=i&(-i)) {
sum += bit[i];
}
return sum;
}
void preprocess() {
for(int i=0;i<=n;i++) {
lc[i] = i - 1;
rc[i] = i + 1;
}
rc[n] = -1;
}
int bin_search(int val) {
int index = n;
if(query(index) < val) return n+1;
for(int cekor = n; cekor > 0; cekor/=2) {
while(index - cekor >= 0 && query(index-cekor)>=val) index-=cekor;
}
return index;
}
int recursion(int i) {
if(answ[i] != -1) return answ[i];
int l = intervals[i].first;
int r = intervals[i].second;
int after = r - 1;
int before = l - 1;
int cnt = pref[after] - pref[before];
if(cnt == 0) {
answ[i] = 1;
if(parent[i] != -1) answ[i] += recursion(parent[i]);
}
else {
answ[i] = 0;
}
return answ[i];
}
int GetBestPosition(int N, int C, int R, int *K, int *S, int *E) {
n = N; r = R; q = C;
preprocess();
for(int i=1;i<=n;i++) update(i, 1);
memset(curr_intv, -1, sizeof(curr_intv));
memset(parent, -1, sizeof(parent));
memset(answ, -1, sizeof(answ));
for(int i=0;i<q;i++) {
int l = bin_search(S[i]+1);
int r = bin_search(E[i]+2) - 1;
intervals[i] = mp(l, r);
if(curr_intv[l] != -1) {
parent[curr_intv[l]] = i;
curr_intv[l] = i;
}
else curr_intv[l] = i;
//cout<<"Q:"<<i<<" -> "<<l<<" "<<r<<"\n";
for(int j=rc[l];j<=r && j!=-1;j=rc[j]) {
//cout<<"upd: "<<j<<"\n";
// set this value to 0
if(curr_intv[j] != -1) {
parent[curr_intv[j]] = i;
curr_intv[j] = i;
}
else curr_intv[j] = i;
rc[lc[j]] = rc[j];
lc[rc[j]] = lc[j];
update(j, -1);
}
}
for(int i=1;i<n;i++) {
pref[i] = pref[i-1];
if(K[i-1] > r) pref[i]++;
}
int maxm = 0, ind = 1;
for(int i=0;i<q;i++) {
int curr = recursion(i);
if(curr > maxm) {
maxm = curr;
ind = intervals[i].first;
}
else if(curr == maxm) {
ind = min(ind, intervals[i].first);
}
}
return ind - 1;
}
/*int arr[maxn], s[maxn], e[maxn];
int main() {
//ifstream fin("input.txt");
int n, c, r;
cin>>n>>c>>r;
for(int i=0;i<n-1;i++) cin>>arr[i];
for(int i=0;i<c;i++) cin>>s[i]>>e[i];
cout<<GetBestPosition(n, c, r, arr, s, e);
return 0;
}*/
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
3 ms |
1528 KB |
Output is correct |
2 |
Correct |
4 ms |
1636 KB |
Output is correct |
3 |
Correct |
3 ms |
1636 KB |
Output is correct |
4 |
Correct |
4 ms |
1760 KB |
Output is correct |
5 |
Correct |
4 ms |
1760 KB |
Output is correct |
6 |
Correct |
4 ms |
1768 KB |
Output is correct |
7 |
Correct |
4 ms |
1840 KB |
Output is correct |
8 |
Correct |
5 ms |
1896 KB |
Output is correct |
9 |
Correct |
3 ms |
1908 KB |
Output is correct |
10 |
Correct |
3 ms |
1980 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
1980 KB |
Output is correct |
2 |
Correct |
9 ms |
2172 KB |
Output is correct |
3 |
Correct |
5 ms |
2172 KB |
Output is correct |
4 |
Correct |
9 ms |
2264 KB |
Output is correct |
5 |
Correct |
11 ms |
2328 KB |
Output is correct |
6 |
Correct |
7 ms |
2328 KB |
Output is correct |
7 |
Correct |
10 ms |
2444 KB |
Output is correct |
8 |
Correct |
9 ms |
2640 KB |
Output is correct |
9 |
Correct |
4 ms |
2640 KB |
Output is correct |
10 |
Correct |
10 ms |
2684 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
56 ms |
3916 KB |
Output is correct |
2 |
Correct |
121 ms |
8060 KB |
Output is correct |
3 |
Correct |
36 ms |
8060 KB |
Output is correct |
4 |
Correct |
115 ms |
10016 KB |
Output is correct |
5 |
Correct |
111 ms |
11664 KB |
Output is correct |
6 |
Correct |
114 ms |
12088 KB |
Output is correct |
7 |
Correct |
143 ms |
14760 KB |
Output is correct |
8 |
Correct |
127 ms |
16348 KB |
Output is correct |
9 |
Correct |
26 ms |
16348 KB |
Output is correct |
10 |
Correct |
31 ms |
16348 KB |
Output is correct |