CodeVS 数轴染色

时间:2021-07-30 02:54:51
#include<cstdio>
#include<algorithm>
using namespace std; #define lson rt<<1
#define rson rt<<1|1
const int maxn=200010;
int xd[maxn*4],tag[maxn*4],all,n; void pushdown(int l,int r,int rt)
{
if(tag[rt]==1)
{
xd[lson]=xd[rson]=1;
tag[lson]=tag[rson]=1;
tag[rt]=0;
}
} void update(int l,int r,int rt,int a,int b)
{
int mid=(l+r)>>1;
if(a<=l && b>=r)
{
if(xd[rt]==0)
{
xd[rt]=1;
all-=r-l+1;
tag[rt]=1;
}
else if(xd[rt]==1)
{
return;
}
else
{
xd[rt]=1;
update(l,mid,lson,a,b);
update(mid+1,r,rson,a,b);
}
return;
} pushdown(l,r,rt); if(a<=mid){ update(l,mid,lson,a,b);}
if(b>=mid+1) {update(mid+1,r,rson,a,b);}
if(xd[lson]==1 && xd[rson]==1)
{
xd[rt]=1;
}
else if(xd[lson]==0 && xd[rson]==0)
{
xd[rt]=0;
}
else
{
xd[rt]=-1;
}
} int main()
{
scanf("%d%d",&all,&n);
int nn=all;
for(int i=1,a,b;i<=n;i++)
{
scanf("%d%d",&a,&b);
update(1,nn,1,a,b);
printf("%d\n",all);
}
return 0;
}