Submission #543380

#TimeUsernameProblemLanguageResultExecution timeMemory
543380LoboJousting tournament (IOI12_tournament)C++17
0 / 100
62 ms7632 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...