# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
79612 | triplem5ds | Meteors (POI11_met) | C++14 | 639 ms | 66560 KiB |
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;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 3e5+5;
int lo[N], hi[N];
int n, m, k;
int a[N]; ///Meteor States
int cap[N]; ///Cap for each meteor
int l[N], r[N], add[N];
int val[N];
/*
If i parallel binary search how should i handle
the L[i], R[i] updates with segment tree
*/
vector<int> corrsponds[N];
int ans[N];
vector<int> qu[2][N];
const int off = 512*512;
ll laz[off<<1];
void upd(int l, int r,int v){
l += off;
r += off;
laz[l]+=v;
if(l!=r)laz[r]+=v;
while(l+1<r){
if(l&1^1)laz[l+1]+=v;
if(r&1)laz[r-1]+=v;
l >>= 1;
r >>= 1;
}
}
ll qry(int idx){
ll ret = 0;idx++;
for(int i = off+idx;i>=1;i>>=1)
ret += laz[i];
return ret;
}
int main(){
#ifdef ONLINE_JUDGE
ios_base::sync_with_stdio(0);
cin.tie(0);
#endif // ONLINE_JUDGE
memset(ans,-1,sizeof ans);
scanf("%d%d", &n, &m);
for(int i = 0; i < m; i++){
scanf("%d", a + i); --a[i];
corrsponds[a[i]].push_back(i);
}
for(int i = 0; i < n; i++)
scanf("%d", cap + i);
scanf("%d", &k);
for(int i = 0; i < k; i++)
scanf("%d%d%d", l + i, r + i, add + i), --l[i], --r[i];
for(int i = 0; i < n; i++){
hi[i] = k;
qu[0][(lo[i]+hi[i]) >> 1].push_back(i);
}
for(int i = 0; i < 20; i++){
// cerr << "Search : " << i << '\n';
for(int j = 0; j < k; j++)qu[i&1^1][j].clear();
for(int j = 0; j < k; j++){
if(l[j] <= r[j])
upd(l[j]+1,r[j]+1,add[j]);
else
upd(l[j]+1,off-1,add[j]),
upd(0,r[j]+1,add[j]);
for(auto v : qu[i&1][j]){
ll sum = 0;
for(auto x : corrsponds[v]){
sum += qry(x);
if(sum >= cap[v])break;
}
if(sum >= cap[v])
hi[v] = j;
else
lo[v] = j + 1;
if(lo[v] < hi[v])
qu[i&1^1][(lo[v]+hi[v])>>1].push_back(v);
}
}
for(int j = 0; j < k; j++){
if(l[j] <= r[j])
upd(l[j]+1,r[j]+1,-add[j]);
else
upd(l[j]+1,off-1,-add[j]),
upd(0,r[j]+1,-add[j]);
}
}
for(int i = 0; i < n; i++)
if(lo[i] == k)
puts("NIE");
else
printf("%d\n", lo[i]+1);
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |