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<bits/stdc++.h>
using namespace std;
const long long inf = (long long) 1e18 + 10;
const int inf1 = (int) 1e9 + 10;
#define int long long
#define dbl long double
#define endl '\n'
#define sc second
#define fr first
#define mp make_pair
#define pb push_back
#define all(x) x.begin(), x.end()
const int maxn = 1e5+10;
int n, lz[4*maxn], trlz[4*maxn], L[maxn], R[maxn], ps[maxn], last[maxn], nx[maxn];
pair<int,int> tr[4*maxn];
void flush(int no, int l, int r) {
if(lz[no] == 0) return;
trlz[no]+= lz[no];
if(l != r) {
int f1 = 2*no;
int f2 = 2*no+1;
int mid = (l+r)/2;
lz[f1]+= lz[no];
lz[f2]+= lz[no];
}
lz[no] = 0;
}
void attlz(int no, int l, int r, int L, int R, int val) {
flush(no,l,r);
if(l > R || r < L) return;
else if(l >= L && r <= R) {
lz[no] = val;
flush(no,l,r);
return;
}
int f1 = 2*no;
int f2 = 2*no+1;
int mid = (l+r)/2;
attlz(f1,l,mid,L,R,val);
attlz(f2,mid+1,r,L,R,val);
trlz[no] = max(trlz[f1],trlz[f2]);
}
int findseg(int no, int l, int r, int val) {
if(l == r) {
return l;
}
int f1 = 2*no;
int f2 = 2*no+1;
int mid = (l+r)/2;
flush(no,l,r);
flush(f1,l,mid);
flush(f2,mid+1,r);
if(trlz[f1] < val) {
return findseg(f2,mid+1,r,val);
}
else {
return findseg(f1,l,mid,val);
}
}
void attmx(int no, int l, int r, int pos, int val, int id) {
if(l > pos || r < pos) return;
else if(l == r) {
tr[no] = max(tr[no],mp(val,id));
return;
}
int f1 = 2*no;
int f2 = 2*no+1;
int mid = (l+r)/2;
attmx(f1,l,mid,pos,val,id);
attmx(f2,mid+1,r,pos,val,id);
tr[no] = max(tr[f1],tr[f2]);
}
pair<int,int> qrrmx(int no, int l, int r, int L, int R) {
if(l > R || r < L) return mp(0,0);
else if(l >= L && r <= R) {
return tr[no];
}
int f1 = 2*no;
int f2 = 2*no+1;
int mid = (l+r)/2;
return max(qrrmx(f1,l,mid,L,R),qrrmx(f2,mid+1,r,L,R));
}
int32_t GetBestPosition(int32_t N, int32_t C, int32_t R1, int32_t *K, int32_t *S, int32_t *E) {
n = N;
for(int i = 0; i < N-1; i++) {
if(K[i] > R1) {
ps[i] = 1;
}
if(i != 0) ps[i]+= ps[i-1];
}
for(int i = 0; i < n; i++) {
attlz(1,0,N-1,i,i,i);
last[i] = i;
}
for(int i = 0; i < C; i++) {
//encontra o proximo do cara
L[i] = findseg(1,0,n-1,S[i]);
R[i] = last[findseg(1,0,n-1,E[i])];
// cout << E[i] << " " << findseg(1,0,n-1,E[i]) << endl;
if(L[i] != R[i]) attlz(1,0,n-1,L[i]+1,R[i],-n);
if(R[i] != n-1) attlz(1,0,n-1,R[i]+1,n-1,-(E[i]-S[i]));
last[L[i]] = R[i];
// cout << i << " " << S[i] << "," << E[i] << " " << L[i] << "," << R[i] << endl;
}
vector<pair<int,int>> v;
for(int i = 0; i < C; i++) {
v.pb(mp(R[i]-L[i],i));
}
sort(all(v));
for(int i = 0; i < C; i++) {
int id = v[i].sc;
nx[id] = id;
if(ps[R[id]-1] - (L[id] == 0 ? 0 : ps[L[id]-1]) > 0) continue;
auto qr = qrrmx(1,0,n,L[id],R[id]);
nx[id] = qr.sc;
if(qr.fr == 0) nx[id] = id;
attmx(1,0,n-1,L[id],qr.fr+1,id);
}
auto qr = qrrmx(1,0,n-1,0,n-1);
int32_t ans = qr.sc;
while(nx[ans] != ans) {
ans = nx[ans];
}
return L[ans];
}
// int32_t main() {
// ios::sync_with_stdio(false); cin.tie(0);
// freopen("in.in", "r", stdin);
// // freopen("out.out", "w", stdout);
// int32_t N, C, R; cin >> N >> C >> R;
// int32_t *K, *S, *E;
// K = (int32_t*) malloc((N-1) * sizeof(int32_t));
// S = (int32_t*) malloc(C * sizeof(int32_t));
// E = (int32_t*) malloc(C * sizeof(int32_t));
// for(int i = 0; i < N-1; i++) {
// cin >> K[i];
// }
// for(int i = 0; i < C; i++) {
// cin >> S[i] >> E[i];
// }
// cout << GetBestPosition(N,C,R,K,S,E) << endl;
// }
Compilation message (stderr)
tournament.cpp: In function 'void flush(long long int, long long int, long long int)':
tournament.cpp:27:13: warning: unused variable 'mid' [-Wunused-variable]
27 | int mid = (l+r)/2;
| ^~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |