1191 数轴染色
时间限制: 1 s
空间限制: 128000 KB
题目等级 : 黄金 Gold
题目描述 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
分类标签 Tags
线段树 树结构
/*
W.
lazy设为0 1两种状态.
题中数据有误QWQ.
*/
#include<iostream>
#include<cstdio>
#define MAXN 200001
#define LL long long
using namespace std;
int n,m,cut;
struct data
{
int sum;
bool bj;
int lc,rc;
int l,r;
int tot;
}
tree[MAXN*4];
void build(int l,int r)
{
int k=++cut;
tree[k].l=l,tree[k].r=r;
if(l==r)
{
tree[k].sum=1;
return ;
}
int mid=(l+r)>>1;
tree[k].lc=cut+1;
build(l,mid);
tree[k].rc=cut+1;
build(mid+1,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
void up(int k)
{
tree[tree[k].lc].bj=true;
tree[tree[k].rc].bj=true;
tree[k].bj=0;
}
void add(int k,int l,int r)
{
if(l<=tree[k].l&&tree[k].r<=r)
{
tree[k].bj=1;
tree[k].sum-=(tree[k].r-tree[k].l+1);
tree[k].sum=max(0,tree[k].sum);
return ;
}
if(tree[k].bj) up(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(r<=mid) add(tree[k].lc,l,r);
else if(l>mid) add(tree[k].rc,l,r);
else add(tree[k].lc,l,mid),add(tree[k].rc,mid+1,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
int query(int k,int l,int r)
{
if(l<=tree[k].l&&tree[k].r<=r)
{
return tree[k].sum;
}
LL tot=0;
if(l==r) return 0;
if(tree[k].bj) up(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(r<=mid) tot+=query(tree[k].lc,l,r);
else if(l>mid) tot+=query(tree[k].rc,l,r);
else tot+=query(tree[k].lc,l,mid),tot+=query(tree[k].rc,mid+1,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
return tot;
}
int main()
{
int a,b;
cin>>n>>m;
build(1,n);
for(int i=1;i<=m;i++)
{
cin>>a>>b;
add(1,a,b);query(1,1,n);
printf("%d\n",tree[1].sum);
}
return 0;
}
/*
A.
区间修改+区间查询.
题中数据明显有问题QWQ.
*/
#include<iostream>
#include<cstdio>
#define MAXN 200001
#define ll long long
using namespace std;
ll n,m,tot,cut,aa[MAXN+10];
struct data
{
int l,r;
int lc,rc;
int sum;
ll bj;
}tree[MAXN*4];
void build(int l,int r)
{
int k=++cut;
tree[k].l=l;
tree[k].r=r;
if(l==r)
{
tree[k].sum=1;
return ;
}
int mid=(l+r)>>1;
tree[k].lc=cut+1;
build(l,mid);
tree[k].rc=cut+1;
build(mid+1,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
void updata(int k)
{
tree[tree[k].lc].sum+=
tree[k].bj*(tree[tree[k].lc].r-tree[tree[k].lc].l+1);
tree[tree[k].rc].sum+=
tree[k].bj*(tree[tree[k].rc].r-tree[tree[k].rc].l+1);
tree[tree[k].lc].bj+=tree[k].bj;
tree[tree[k].rc].bj+=tree[k].bj;
tree[k].bj=0;
tree[tree[k].lc].sum=max(tree[tree[k].lc].sum,0);
tree[tree[k].rc].sum=max(tree[tree[k].rc].sum,0);
}
void add(int k,int l,int r,int add1)
{
if(l<=tree[k].l&&tree[k].r<=r)
{
tree[k].bj-=add1;
tree[k].sum-=add1*(tree[k].r-tree[k].l+1);
tree[k].sum=max(0,tree[k].sum);
return ;
}
if(tree[k].bj) updata(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(l<=mid) add(tree[k].lc,l,r,add1);
if(r>mid) add(tree[k].rc,l,r,add1);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
ll query(int k,int l,int r)
{
if(l<=tree[k].l&&tree[k].r<=r) return tree[k].sum;
ll tot=0;
if(tree[k].bj) updata(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(l<=mid) tot+=query(tree[k].lc,l,r);
if(r>mid) tot+=query(tree[k].rc,l,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
return tot;
}
int main()
{
int x,a,b,add1;
cin>>n;
build(1,n);
cin>>m;
for(int i=1;i<=m;i++)
{
scanf("%d %d",&a,&b);
add(1,a,b,1);
printf("%lld\n",query(1,1,n));
}
return 0;
}
Codevs 1191 数轴染色的更多相关文章
-
codevs 1191 数轴染色 区间更新加延迟标记
题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色.请输出每个操作执行后剩余黑色点的个数. ...
-
【wikioi】1191 数轴染色(线段树+水题)
http://wikioi.com/problem/1191/ 太水的线段树了,敲了10分钟就敲完了,但是听说还有一种并查集的做法?不明觉厉. #include <cstdio> #inc ...
-
codevs 1191 树轴染色 线段树区间定值,求和
codevs 1191 树轴染色 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.codevs.cn/problem/1191/ Des ...
-
【codevs1191】数轴染色 线段树 区间修改+固定区间查询
[codevs1191]数轴染色 2014年2月15日4317 题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着我们进行M次操作,第i次操作将[L ...
-
T1191 数轴染色 codevs
http://codevs.cn/problem/1191/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descr ...
-
CodeVS 数轴染色
#include<cstdio> #include<algorithm> using namespace std; #define lson rt<<1 #defi ...
-
codevs 1049 棋盘染色
题目描述 Description 有一个5×5的棋盘,上面有一些格子被染成了黑色,其他的格子都是白色,你的任务的对棋盘一些格子进行染色,使得所有的黑色格子能连成一块,并且你染色的格子数目要最少.读入一 ...
-
wikioi1191 数轴染色
题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着 我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色.请输出每个操作执行后 剩余黑色点的个 ...
-
codevs 1191 线段树 区间更新(水)
题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色.请输出每个操作执行后剩余黑色点的个数. ...
随机推荐
-
mac 无法识别seagate硬盘、无法向其写入文件
1,无法识别 Seagate 硬盘 新买的mac air Captian 10.11.6系统,连上硬盘根本不出现盘符,usb插头不要插得太深,慢慢的插入,看到硬盘白灯亮起就可以了 2,无法向 Seag ...
-
XSS攻击及防御
XSS又称CSS,全称Cross SiteScript,跨站脚本攻击,是Web程序中常见的漏洞,XSS属于被动式且用于客户端的攻击方式,所以容易被忽略其危害性.其原理是攻击者向有XSS漏洞的网站中输入 ...
-
Web Component 文章
周末无意中了解了Web Component的概念. http://blog.amowu.com/2013/06/web-components.html http://www.v2ex.com/t/69 ...
-
Windows Azure 配置多个站点的虚拟网络连接
通过上一篇"Windows Azure 虚拟网络配置(Site to Site)" 我们建立了可以进行Site to Site连接的虚拟网络,配置过后有些朋友会有疑问:如果需要连接 ...
-
JQuery处理json与ajax返回JSON实例
一.JSON的一些基础知识. JSON中对象通过“{}”来标识,一个“{}”代表一个对象,如{“AreaId”:”123”},对象的值是键值对的形式(key:value). “[]”,标识数组,数组内 ...
-
log4jdbc
log4jdbc http://www.blogjava.net/badqiu/archive/2010/08/20/329464.html http://blog.csdn.net/sfdev/ar ...
-
有哪些适合学生参与的 C++,网络编程方面的开源项目?
有哪些适合学生参与的 C++,网络编程方面的开源项目? Tinyhttpd是一个超轻量型Http Server,使用C语言开发,全部代码只有502行(包括注释),附带一个简单的Client,可以通 ...
-
AdbWinApi编译详解(本人亲历)
1. 从微软官方下载WDDK,比如:GRMWDK_EN_7600_1.ISO(http://download.microsoft.com/download/4/A/2/4A25C7D5-EFBE-41 ...
-
phpcms 制作简单企业站的常用标签
标题 title 关键字 keywords 描述 description 来源 copyfrom 允许访问 allow_visitor==1 thumb 缩略图 {template "con ...
-
Java自学开发编程路线图(文中有资源福利)
Java 语言入门 免费视频资源<毕向东Java基础教程>:http://yun.itheima.com/course/7.html JavaEE 学习大纲 所处阶段 主讲内容 技术要点 ...