POJ 3468 A Simple Problem with Integers //线段树的成段更新
| Time Limit: 5000MS | Memory Limit: 131072K | |
| Total Submissions: 59046 | Accepted: 17974 | |
| Case Time Limit: 2000MS | ||
Description
You have N integers, A1, A2, ... , AN. You need to deal with two kinds of operations. One type of operation is to add some given number to each number in a given interval. The other is
to ask for the sum of numbers in a given interval.
Input
The first line contains two numbers N and Q. 1 ≤ N,Q ≤ 100000.
The second line contains N numbers, the initial values of A1, A2, ... , AN. -1000000000 ≤ Ai ≤ 1000000000.
Each of the next Q lines represents an operation.
"C a b c" means adding c to each of Aa, Aa+1, ... , Ab. -10000 ≤ c ≤ 10000.
"Q a b" means querying the sum of Aa, Aa+1, ... , Ab.
Output
You need to answer all Q commands in order. One answer in a line.
Sample Input
10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4
Sample Output
4
55
9
15
Hint
Source
/*
区间更新的lazy操作。
*/
#include <stdio.h> struct node
{
int l, r;
__int64 sum;
__int64 lazy; //当成段更新时,往往不用更新到单个的点。lazy操作大大节省了时间。
}tree[300005];
int h[100005];
__int64 sum; //int超限 void build(int l, int r, int n)
{
int mid;
tree[n].l = l;
tree[n].r = r;
tree[n].lazy = 0; //赋初值
if(l==r)
{
tree[n].sum = h[l];
return ;
}
mid = (l+r)/2;
build(l, mid, 2*n);
build(mid+1, r, 2*n+1); tree[n].sum = tree[2*n].sum+tree[2*n+1].sum;
}
void add(int l, int r, __int64 k, int n)
{
int mid;
if(tree[n].l==l && tree[n].r==r) //当须要更新的段 与 结点相应的段吻合时,直接把此结点的lazy值更新就可以,不须要再向下更新。
{
tree[n].lazy += k;
return;
} tree[n].sum += k*(r-l+1); //当此区间包括须要更新的区间,但不吻合时,须要向下继续查找,此时须要更新这个父节点的sum值。 mid = (tree[n].l + tree[n].r)/2;
if(r <= mid)
add(l, r, k, 2*n);
else if(l >=mid+1)
add(l, r, k, 2*n+1);
else
{
add(l, mid, k, 2*n);
add(mid+1, r, k, 2*n+1);
}
}
void qu(int l, int r, int n)
{
int mid;
if(tree[n].l==l && tree[n].r==r)
{
sum += tree[n].sum + (r-l+1)*tree[n].lazy; //当查找的段与 此结点的段吻合时,sum 值等于这个结点的sum加上lazy乘区间长度的值。
return ;
} if(tree[n].lazy!=0 && tree[n].l!=tree[n].r) //当查找区间为此结点相应区间的子集时,须要将此结点相应的lazy值下放到其子节点,并把此结点的lazy值置为0。
{
add(tree[2*n].l, tree[2*n].r, tree[n].lazy, n);
add(tree[2*n+1].l, tree[2*n+1].r, tree[n].lazy, n);
tree[n].lazy = 0;
}
mid = (tree[n].l + tree[n].r)/2; if(l >= mid+1)
qu(l, r, 2*n+1);
else if(r <= mid)
qu(l, r, 2*n);
else
{
qu(l, mid, 2*n);
qu(mid+1, r, 2*n+1);
}
} int main()
{
int n, q;
int i;
int a, b, c;
char ch[10]; scanf("%d%d", &n, &q);
for(i=1; i<=n; i++)
scanf("%d", &h[i]); build(1, n, 1);
while(q--)
{
scanf("%s", ch);
if(ch[0]=='Q')
{
scanf("%d%d", &a, &b);
sum = 0;
qu(a, b, 1);
printf("%I64d\n", sum);
}
else
{
scanf("%d%d%d", &a, &b, &c);
add(a, b, c, 1);
}
}
return 0;
}
POJ 3468 A Simple Problem with Integers //线段树的成段更新的更多相关文章
- POJ3648 A Simple Problem with Integers(线段树之成段更新。入门题)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 53169 Acc ...
- poj 3468 A Simple Problem with Integers 线段树区间加,区间查询和
A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://poj.org/problem?i ...
- poj 3468 A Simple Problem with Integers 线段树区间加,区间查询和(模板)
A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://poj.org/problem?i ...
- poj 3468 A Simple Problem with Integers 线段树第一次 + 讲解
A Simple Problem with Integers Description You have N integers, A1, A2, ... , AN. You need to deal w ...
- [POJ] 3468 A Simple Problem with Integers [线段树区间更新求和]
A Simple Problem with Integers Description You have N integers, A1, A2, ... , AN. You need to deal ...
- poj 3468 A Simple Problem with Integers (线段树区间更新求和lazy思想)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 75541 ...
- POJ 3468 A Simple Problem with Integers(线段树 成段增减+区间求和)
A Simple Problem with Integers [题目链接]A Simple Problem with Integers [题目类型]线段树 成段增减+区间求和 &题解: 线段树 ...
- poj 3468 A Simple Problem with Integers 线段树加延迟标记
A Simple Problem with Integers Description You have N integers, A1, A2, ... , AN. You need to deal ...
- poj 3468 A Simple Problem with Integers 线段树区间更新
id=3468">点击打开链接题目链接 A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072 ...
随机推荐
- Netmon: A light-weight network monitor for Windows
Netmon is a light-weight network monitor that works on Windows operating systems. It provides differ ...
- mysql主从监控
要求:检测myslq从库状态,跳过固定的错误号,每隔30秒检测一次,如果符合条件自动跳过或者是重启从库 1)取出mysql从库的关键字 [root@localhost scripts]# mysql ...
- Windows server 2008系统下FTP服务器的安装
一.在 Windows 服务器上安装 FTP 服务 1. 在"开始"菜单上,单击"管理工具",然后单击"服务器管理器". 2. 在" ...
- Access to the path '....' is denied.解决方法
昨天公司项目迁移服务器,从自己服务器迁移到阿里云服务器,部署完成后发现有一个页面要读取磁盘上的静态文件就报错了... 如图: 解决办法: 在 Web.Config 的 <System.Web&g ...
- 获取scrollTop兼容各浏览器的方法,以及body和documentElement
1.各浏览器下 scrollTop的差异 IE6/7/8: 对于没有doctype声明的页面里可以使用 document.body.scrollTop 来获取 scrollTop高度 : 对于有do ...
- Uploadify插件使用方法
1.下载所需文件 2.导入所需文件,还需要应用jquery.js文件 3.导入css.js uploadify.css.jquery.uploadify.min.js 4.前端代码 p标签存放uplo ...
- dbcp写连接池 Demo
1.导包 2.准备配置文件 .properties(注:这里的参数名driverClassName.url.username等是不能改变的) 不能任意命名的原因是[你懂得] 3.Demo publ ...
- java学习笔记 (2) —— Struts2类型转换、数据验证重要知识点
1.*Action.conversion-properties 如(point=com.test.Converter.PointListConverter) 具体操作类的配置文件 2.*Action. ...
- PS 色彩的色相谱
7- 色彩的色相谱 在这个环中,位于180度夹角的两种颜色(也就是圆的某条直径两端的颜色),称为反转色,又称为互补色.互补的两种颜色之间是此消彼长的关系,小框往蓝色移动的同时就会远离黄色, 黄色=白色 ...
- 在PHP中开启CURL扩展,使其支持curl()函数
在用PHP开发CMS的时候,要用到PHP的curl函数,默认状态下,这个函数需要开启CURL扩展,有主机使用权的,可通过PHP.ini文件开启本扩展,方法如下: 1.打开php.ini,定位到;ext ...