线段树(成段更新,区间求和lazy操作 )
Color the ball
当N = 0,输入结束。
3
1 1
2 2
3 3
3
1 1
1 2
1 3
0
1 1 1
3 2 1
<pre name="code" class="cpp">#include"stdio.h"
#include"string.h"
#include"iostream"
#include"map"
#include"string"
#include"queue"
#include"stdlib.h"
#include"math.h"
#define M 100009
#define eps 1e-8
#define inf 1000000000
#define mod 1000000000
#define INF 1000000000
using namespace std;
struct st
{
int l,r,sum,add,mark;
}a[M*4];
int ans;
void make(int l,int r,int k)
{
a[k].l=l;
a[k].r=r;
a[k].mark=0;
a[k].add=0;
if(l==r)
{
a[k].sum=0;
return ;
}
int mid=(l+r)/2;
make(l,mid,k*2);
make(mid+1,r,k*2+1);
a[k].sum=a[k*2].sum+a[k*2+1].sum;
}
void updata(int l,int r,int p,int k)
{
if(a[k].l==l&&a[k].r==r)
{
a[k].sum+=(r-l+1);
a[k].add+=p;//当多次刚好更新还区间的时候,只更新到该区间,所以要连加
a[k].mark=1;
return;
}
if(a[k].mark)
{
a[k*2].sum+=(a[k*2].r-a[k*2].l+1)*a[k].add;
a[k*2].add+=a[k].add;
a[k*2].mark=1;
a[k*2+1].sum+=(a[k*2+1].r-a[k*2+1].l+1)*a[k].add;
a[k*2+1].add+=a[k].add;
a[k*2+1].mark=1;
a[k].mark=0;
a[k].add=0;//当向下延伸的时候,需要把当前区间赋为0,
}
int mid=(a[k].l+a[k].r)/2;
if(r<=mid)
updata(l,r,p,k*2);
else if(l>mid)
updata(l,r,p,k*2+1);
else
{
updata(l,mid,p,k*2);
updata(mid+1,r,p,k*2+1);
}
a[k].sum=a[k*2].sum+a[k*2+1].sum;
}
void query(int p,int k)
{
if(a[k].l==p&&a[k].r==p)
{
ans+=a[k].sum;
return;
}
if(a[k].mark)
{
a[k*2].sum+=(a[k*2].r-a[k*2].l+1)*a[k].add;
a[k*2].add+=a[k].add;
a[k*2].mark=1;
a[k*2+1].sum+=(a[k*2+1].r-a[k*2+1].l+1)*a[k].add;
a[k*2+1].add+=a[k].add;
a[k*2+1].mark=1;
a[k].mark=0;
a[k].add=0;
}
int mid=(a[k].l+a[k].r)/2;
if(p<=mid)
query(p,k*2);
else
query(p,k*2+1);
a[k].sum=a[k*2].sum+a[k*2+1].sum;
}
int main()
{
int n,i;
while(scanf("%d",&n),n)
{
make(1,n,1);
int x,y;
for(i=1;i<=n;i++)
{
scanf("%d%d",&x,&y);
updata(x,y,1,1);
}
for(i=1;i<=n;i++)
{
ans=0;
query(i,1);
if(i==1)
printf("%d",ans);
else
printf(" %d",ans);
}
printf("\n");
}
return 0;
}
线段树(成段更新,区间求和lazy操作 )的更多相关文章
- HDU 3577 Fast Arrangement ( 线段树 成段更新 区间最值 区间最大覆盖次数 )
线段树成段更新+区间最值. 注意某人的乘车区间是[a, b-1],因为他在b站就下车了. #include <cstdio> #include <cstring> #inclu ...
- POJ 3468 A Simple Problem with Integers(线段树 成段增减+区间求和)
A Simple Problem with Integers [题目链接]A Simple Problem with Integers [题目类型]线段树 成段增减+区间求和 &题解: 线段树 ...
- poj 3468 线段树 成段增减 区间求和
题意:Q是询问区间和,C是在区间内每个节点加上一个值 Sample Input 10 51 2 3 4 5 6 7 8 9 10Q 4 4Q 1 10Q 2 4C 3 6 3Q 2 4Sample O ...
- POJ训练计划2777_Count Color(线段树/成段更新/区间染色)
解题报告 题意: 对线段染色.询问线段区间的颜色种数. 思路: 本来直接在线段树上染色,lz标记颜色.每次查询的话訪问线段树,求出颜色种数.结果超时了,最坏的情况下,染色能够染到叶子节点. 换成存下区 ...
- poj 3669 线段树成段更新+区间合并
添加 lsum[ ] , rsum[ ] , msum[ ] 来记录从左到右的区间,从右到左的区间和最大的区间: #include<stdio.h> #define lson l,m,rt ...
- POJ3468_A Simple Problem with Integers(线段树/成段更新)
解题报告 题意: 略 思路: 线段树成段更新,区间求和. #include <iostream> #include <cstring> #include <cstdio& ...
- ACM: Copying Data 线段树-成段更新-解题报告
Copying Data Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description W ...
- POJ 2777 Count Color (线段树成段更新+二进制思维)
题目链接:http://poj.org/problem?id=2777 题意是有L个单位长的画板,T种颜色,O个操作.画板初始化为颜色1.操作C讲l到r单位之间的颜色变为c,操作P查询l到r单位之间的 ...
- hdu 4747【线段树-成段更新】.cpp
题意: 给出一个有n个数的数列,并定义mex(l, r)表示数列中第l个元素到第r个元素中第一个没有出现的最小非负整数. 求出这个数列中所有mex的值. 思路: 可以看出对于一个数列,mex(r, r ...
- poj 3468 A Simple Problem with Integers 【线段树-成段更新】
题目:id=3468" target="_blank">poj 3468 A Simple Problem with Integers 题意:给出n个数.两种操作 ...
随机推荐
- 利用Spring AOP和自定义注解实现日志功能
Spring AOP的主要功能相信大家都知道,日志记录.权限校验等等. 用法就是定义一个切入点(Pointcut),定义一个通知(Advice),然后设置通知在该切入点上执行的方式(前置.后置.环绕等 ...
- C的内存四大区
前提 看视频得来的内容,只知道不止4个区,但主要是这4个区. 四区 静态区 用于存放所有的全局变量和静态变量. ; //静态区 int main(){ ; //静态区 ; } 代码区 就是存放程序的执 ...
- UVA 1371 - Period(DP)
题目链接:option=com_onlinejudge&Itemid=8&page=show_problem&category=&problem=4117&mo ...
- ajax basic 认证
//需要Base64见:http://www.webtoolkit.info/javascript-base64.html function make_base_auth(user, password ...
- write solid code 零散(原文)
整理下目录,看了这个文件,幸好未删除. 以下是<write solid code>中的原文摘录. 1.How could I have prevented this bug? 2.How ...
- 浅谈session测试
Session 是用于保持状态的基于 Web 服务器的方法,在 Web 服务器上保持用户的状态信息供在任何时间从任何页访问.Session 允许通过将对象存储在 Web 服务器的内存中在整个用户会话过 ...
- php面向对象(OOP)编程完整教程
http://www.cnblogs.com/xiaochaohuashengmi/archive/2010/09/10/1823042.html
- COOKIE和SESSION关系和区别等
一.cookie介绍 cookie 常用于识别用户.cookie 是服务器留在用户计算机中的小文件.每当相同的计算机通过浏览器请求页面时,它同时会发送 cookie.通过 PHP,您能够创建并取回 c ...
- Jmeter content-type:multipart/form-data温故
本文讲三种content-type以及在Jmeter中对应的参数输入方式 第一部分:目前工作中涉及到的content-type 有三种: content-type:在Request Headers里, ...
- GIS-ArcGIS 与 ThreeJs交互联动
一.从GIS触发Three场景 MapFeatureLayer.on("click", function (evt) { graphicsLayerOfMouse.clear(); ...