【codevs1191】数轴染色 线段树 区间修改+固定区间查询

时间:2023-12-17 13:50:56

【codevs1191】数轴染色

2014年2月15日4317

题目描述 Description

在一条数轴上有N个点,分别是1~N。一开始所有的点都被染成黑色。接着
我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色。请输出每个操作执行后
剩余黑色点的个数。

输入描述 Input Description

输入一行为N和M。下面M行每行两个数Li、Ri

输出描述 Output Description

输出M行,为每次操作后剩余黑色点的个数。

样例输入 Sample Input

10 3
3 3
5 7
2 8

样例输出 Sample Output

9
6
3

数据范围及提示 Data Size & Hint

数据限制
对30%的数据有1<=N<=2000,1<=M<=2000
对100%数据有1<=Li<=Ri<=N<=200000,1<=M<=200000

<:SECTION id=statistics>

题解

只要tr【1】.v的结果

代码

 #include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <queue>
#include <typeinfo>
#include <map>
#include <stack>
typedef long long ll;
using namespace std;
inline ll read()
{
ll x=,f=;
char ch=getchar();
while(ch<''||ch>'')
{
if(ch=='-')f=-;
ch=getchar();
}
while(ch>=''&&ch<='')
{
x=x*+ch-'';
ch=getchar();
}
return x*f;
}
//**************************************************************************************
int ans,hash[];
struct ss
{
int l,r,v;
}tr[*];
int n,m;
void build(int k,int s,int t)
{
tr[k].l=s;
tr[k].r=t;
if(s==t){
tr[k].v=;
return;
}
int mid=(s+t)>>;
build(k<<,s,mid);
build(k<<|,mid+,t);
tr[k].v=tr[k<<].v+tr[k<<|].v;
}
void update(int k,int s,int t)
{
if(tr[k].v==)return;
if(s==tr[k].l&&t==tr[k].r)
{
tr[k].v=;
return ;
}
int mid=(tr[k].l+tr[k].r)>>;
if(t<=mid) update(k<<,s,t);
else if(s>mid)update(k<<|,s,t);
else {
update(k<<,s,mid);
update(k<<|,mid+,t);
}
tr[k].v=tr[k<<].v+tr[k<<|].v;
}
int main()
{ scanf("%d%d",&n,&m);
build(,,n);
int a,b;
for(int i=;i<=m;i++)
{
scanf("%d%d",&a,&b);
ans=;
update(,a,b);
printf("%d\n",tr[].v);
}
return ;
}