# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
502411 | reni | Monkey and Apple-trees (IZhO12_apple) | C++14 | 89 ms | 64048 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<iostream>
#define endl '\n'
#include<bits/stdc++.h>
using namespace std;
struct str
{
long long l=0, r=0, lazy=0, sum=0;
}tree[1000005];
long long last=2;
void update(long long le,long long ri,long long l,long long r,long long ind)
{
if(!tree[ind].l)tree[ind].l=last++;
if(!tree[ind].r)tree[ind].r=last++;
if(l<=le && ri<=r){tree[ind].lazy=1;}
if(tree[ind].lazy)
{
tree[ind].sum=(ri-le+1);
tree[tree[ind].l].lazy=1;
tree[tree[ind].r].lazy=1;
tree[ind].lazy=0;
}
if(l>ri || r<le)return;
if(l<=le && ri<=r)return;
long long mid=(le+ri)/2;
update(le,mid,l,r,tree[ind].l);
update(mid+1,ri,l,r,tree[ind].r);
tree[ind].sum=tree[tree[ind].l].sum+tree[tree[ind].r].sum;
// cout<<le<<" "<<ri<<" "<<tree[tree[ind].l].sum<<" "<<tree[tree[ind].r].sum<<" "<<tree[ind].sum<<endl;
}
long long query(long long le,long long ri,long long l,long long r,long long ind)
{
if(!tree[ind].l)tree[ind].l=last++;
if(!tree[ind].r)tree[ind].r=last++;
if(tree[ind].lazy)
{
tree[ind].sum=(ri-le+1);
tree[tree[ind].l].lazy=1;
tree[tree[ind].r].lazy=1;
tree[ind].lazy=0;
}
if(l<=le && ri<=r){return tree[ind].sum;}
if(l>ri || r<le)return 0;
long long mid=(le+ri)/2;
long long r1=0, r2=0;
if(tree[ind].l)r1=query(le,mid,l,r,tree[ind].l);
if(tree[ind].r)r2=query(mid+1,ri,l,r,tree[ind].r);
tree[ind].sum=tree[tree[ind].l].sum+tree[tree[ind].r].sum;
return r1+r2;
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
long long i,j,t,l,r,m,c=0;
cin>>m;
for(i=0;i<m;i++)
{
cin>>t>>l>>r;
l+=c; r+=c;
if(t==2)
{
update(1,1000000002,l,r,1);
}
else{
c=query(1,1000000002,l,r,1);
cout<<c<<endl;
}
}
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |