Submission #173904

#TimeUsernameProblemLanguageResultExecution timeMemory
173904stefdascaDancing Elephants (IOI11_elephants)C++14
26 / 100
9015 ms3320 KiB
#include<bits/stdc++.h> using namespace std; int n, lg; int vals[150002], srt[150002]; void init(int N, int L, int X[]) { n = N; lg = L; for(int i = 1; i <= N; ++i) srt[i] = X[i-1], vals[i] = X[i-1]; sort(srt + 1, srt + n + 1); srt[n+1] = 2100000000; } int binsearch(int val) { int st = 1; int dr = n; int ans = 0; while(st <= dr) { int mid = (st + dr) / 2; if(srt[mid] <= val) ans = mid, st = mid + 1; else dr = mid - 1; } return ans; } int nw[150002]; int update(int xx, int y) { ++xx; if(n == 2) { vals[xx] = y; if(abs(vals[1] - vals[2]) > lg) return 2; return 1; } int aa = 0; for(int i = 1; i <= n; ++i) if(srt[i] < y && srt[i] != vals[xx]) nw[++aa] = srt[i]; nw[++aa] = y; for(int i = 1; i <= n; ++i) if(srt[i] > y && srt[i] != vals[xx]) nw[++aa] = srt[i]; vals[xx] = y; for(int i = 1; i <= n; ++i) srt[i] = nw[i]; int ans = 0; int st = 0; for(int i = 1; i <= n;) { ++ans; st = srt[i]; while(i <= n && srt[i] - st <= lg) ++i; } // for(int i = 1; i <= n; ++i) // cout << srt[i] << " "; // cout << '\n'; return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...