# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
259563 | 2020-08-08T02:36:43 Z | tqbfjotld | Santa Claus (RMI19_santa) | C++14 | 1000 ms | 4088 KB |
#include <bits/stdc++.h> using namespace std; int T; int n; int numelf; int lastelf; int pos[97000]; bool iself[97000]; int val[97000]; bool test(int d,int bound){ multiset<int> presents; for (int x = 0; x<d; x++){ if (iself[x]){ presents.insert(val[x]); } else{ auto it = presents.lower_bound(val[x]); if (it!=presents.end()) { presents.erase(it); } } } for (int x = d; x<=bound; x++){ if (iself[x]){ presents.insert(val[x]); } } for (int x = d; x<=bound; x++){ if (!iself[x]){ auto it = presents.lower_bound(val[x]); if (it!=presents.end()){ presents.erase(it); } } } //printf("test %d %d returned %d\n",d,bound,presents.empty()); return presents.empty(); } int main(){ scanf("%d",&T); while (T--){ scanf("%d",&n); for (int x = 0; x<n; x++){ scanf("%d",&pos[x]); } lastelf = 0; numelf=0; for (int x = 0; x<n; x++){ int t; scanf("%d",&t); if (t){ iself[x] = false; } else { iself[x] = true; lastelf = max(lastelf,x); numelf++; } } for (int x = 0; x<n; x++){ scanf("%d",&val[x]); } for (int x = 0; x<n; x++){ if (x<lastelf) { printf("-1 "); continue; } if (x<2*numelf-1){ printf("-1 "); continue; } if (!test(0,x)){ printf("-1 "); continue; } int l = 0; int r = x+1; while (l+1<r){ int mid = (l+r)/2; if (test(mid,x)) l = mid; else r = mid; } printf("%d ",2*pos[x]-pos[l]); } printf("\n"); } }
Compilation message
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 384 KB | Output is correct |
2 | Correct | 15 ms | 384 KB | Output is correct |
3 | Execution timed out | 1093 ms | 656 KB | Time limit exceeded |
4 | Execution timed out | 1091 ms | 632 KB | Time limit exceeded |
5 | Execution timed out | 1084 ms | 768 KB | Time limit exceeded |
6 | Execution timed out | 1086 ms | 1024 KB | Time limit exceeded |
7 | Execution timed out | 1079 ms | 1536 KB | Time limit exceeded |
8 | Execution timed out | 1082 ms | 2040 KB | Time limit exceeded |
9 | Execution timed out | 1086 ms | 3960 KB | Time limit exceeded |
10 | Execution timed out | 1093 ms | 4088 KB | Time limit exceeded |