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 ...
随机推荐
- Linux编程环境介绍(2) -- shell(Bash) 介绍
1. 在计算机科学中,Shell俗称壳(用来区别于核),是指“提供使用者使用界面”的软件(命令解析器).它类似于DOS下的command和后来的cmd.exe. 2. bash (Bourne Aga ...
- 如何在虚拟机中安装Win7系统
在虚拟机里安装系统,可以很方便我们对系统的各项功能进行测试,而又不会影响本机系统,本节就介绍如何在虚拟机中安装Win7系统 . 工具/原料 vm9虚拟机 电脑一台 方法/步骤 1 在百度上搜索win7 ...
- FoxOne---一个快速高效的BS框架
FoxOne---一个快速高效的BS框架--(1) FoxOne---一个快速高效的BS框架--(2) FoxOne---一个快速高效的BS框架--(3) FoxOne---一个快速高效的BS框架-- ...
- 关于driver_register做了些什么
现在进入driver_register()函数去看看.在driver_register() 中,调用了driver_find(drv->name, drv->bus)函数,这里是干啥呢?这 ...
- python 元类与定制元类
1:元类 元类:类的创建与管理者 所有类的元类是type class a: pass print(type(a)) 结果:<class 'type'> 2:定制元类 类的实例化过程:(可看 ...
- HTML5 为什么这么火?
H5是超文本语言HTML的第五次修订,是近几年来Web标准巨大的飞跃. 以往,我们在Web上还只是上网看一些基础文档,但现在,Web是一个内涵非常丰富的平台.和以前版本不同的是,HTML5并非仅仅用来 ...
- java 连接sql server2008配置
Java 应用程序连接SQL Server2008 (Eclipse+JDK7.0+jdbc4.0.jar+Sql Server2008) 假设应用端的连接语句为: String url = &quo ...
- html 页面实现指定位置的跳转
1.同页面跳转到相应位置 <a href="#id1">跳转到词条1</a> <a href="#id2">跳转到词条2&l ...
- ref和out与SQL中的output
什么时候会需要使用ref和out 有时,我们会需要获取某个值在方法中的运行状态,根据定义的方法,我们仅仅能够获得一个返回值,但是,有时我们也许想获取多个值,通过返回值就不能返回这样的信息,我们可以通过 ...
- (五)JS学习笔记 - Sizzle选择器
Sizzle词法解析 sizzle对于分组过滤处理都用正则,其中都有一个特点,就是都是元字符^开头,限制匹配的初始,所以tokenize也是从左边开始一层一层的剥离. •可能会应用到正则如下: // ...