线段树(成段更新) POJ 3468 A Simple Problem with Integers
/*
线段树-成段更新:裸题,成段增减,区间求和
注意:开long long:)
*/
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std; #define lson l, mid, rt << 1
#define rson mid + 1, r, rt << 1 | 1
#define LL long long const int MAXN = 1e5 + ;
const int INF = 0x3f3f3f3f;
struct Node
{
LL sum, add;
}node[MAXN << ]; void push_up(int rt)
{
node[rt].sum = node[rt<<].sum + node[rt<<|].sum;
} void push_down(int rt, int c)
{
if (node[rt].add)
{
node[rt<<].add += node[rt].add;
node[rt<<|].add += node[rt].add;
node[rt<<].sum += node[rt].add * (c - (c >> ));
node[rt<<|].sum += node[rt].add * (c >> );
node[rt].add = ;
}
} void build(int l, int r, int rt)
{
node[rt].add = ;
if (l == r) {scanf ("%I64d", &node[rt].sum); return ;}
int mid = (l + r) >> ;
build (lson); build (rson); push_up (rt);
} void updata(int ql, int qr, int c, int l, int r, int rt)
{
if (ql <= l && r <= qr) {node[rt].sum += (LL) c * (r - l + ); node[rt].add += c; return ;} push_down (rt, r - l + ); int mid = (l + r) >> ;
if (ql <= mid) updata (ql, qr, c, lson);
if (qr > mid) updata (ql, qr, c, rson); push_up (rt);
} LL query(int ql, int qr, int l, int r, int rt)
{
if (ql <= l && r <= qr) return node[rt].sum; push_down (rt, r - l + ); int mid = (l + r) >> ; LL ans = ;
if (ql <= mid) ans += query (ql, qr, lson);
if (qr > mid) ans += query (ql, qr, rson); return ans;
} int main(void) //POJ 3468 A Simple Problem with Integers
{
//freopen ("POJ_3468.in", "r", stdin); int n, q;
while (scanf ("%d%d", &n, &q) == )
{
build (, n, );
while (q--)
{
char s[]; int ql, qr, c;
scanf ("%s", &s);
if (s[] == 'Q')
{
scanf ("%d%d", &ql, &qr);
printf ("%I64d\n", query (ql, qr, , n, ));
}
else
{
scanf ("%d%d%d", &ql, &qr, &c);
updata (ql, qr, c, , n, );
}
}
} return ;
}
线段树(成段更新) POJ 3468 A Simple Problem with Integers的更多相关文章
- poj 3468 A Simple Problem with Integers 【线段树-成段更新】
题目:id=3468" target="_blank">poj 3468 A Simple Problem with Integers 题意:给出n个数.两种操作 ...
- POJ 2777 Count Color (线段树成段更新+二进制思维)
题目链接:http://poj.org/problem?id=2777 题意是有L个单位长的画板,T种颜色,O个操作.画板初始化为颜色1.操作C讲l到r单位之间的颜色变为c,操作P查询l到r单位之间的 ...
- poj 3648 线段树成段更新
线段树成段更新需要用到延迟标记(或者说懒惰标记),简单来说就是每次更新的时候不要更新到底,用延迟标记使得更新延迟到下次需要更新or询问到的时候.延迟标记的意思是:这个区间的左右儿子都需要被更新,但是当 ...
- ACM: Copying Data 线段树-成段更新-解题报告
Copying Data Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description W ...
- Codeforces Round #149 (Div. 2) E. XOR on Segment (线段树成段更新+二进制)
题目链接:http://codeforces.com/problemset/problem/242/E 给你n个数,m个操作,操作1是查询l到r之间的和,操作2是将l到r之间的每个数xor与x. 这题 ...
- hdu 4747【线段树-成段更新】.cpp
题意: 给出一个有n个数的数列,并定义mex(l, r)表示数列中第l个元素到第r个元素中第一个没有出现的最小非负整数. 求出这个数列中所有mex的值. 思路: 可以看出对于一个数列,mex(r, r ...
- HDU1698_Just a Hook(线段树/成段更新)
解题报告 题意: 原本区间1到n都是1,区间成段改变成一个值,求最后区间1到n的和. 思路: 线段树成段更新,区间去和. #include <iostream> #include < ...
- POJ.3468 A Simple Problem with Integers(线段树 区间更新 区间查询)
POJ.3468 A Simple Problem with Integers(线段树 区间更新 区间查询) 题意分析 注意一下懒惰标记,数据部分和更新时的数字都要是long long ,别的没什么大 ...
- HDU 3577 Fast Arrangement ( 线段树 成段更新 区间最值 区间最大覆盖次数 )
线段树成段更新+区间最值. 注意某人的乘车区间是[a, b-1],因为他在b站就下车了. #include <cstdio> #include <cstring> #inclu ...
随机推荐
- Appium basic UI check cases_from sample
@Test public void testUIComputation() throws Exception { // populate text fields with values populat ...
- peewee模块
Peewee Python中数据库与ORM主要做这几件事: 数据库方面由程序员设计表关系,主要是1v1,1vN,NvN: ORM做数据类型映射,将数据库表示的char/int等类型映射成Python对 ...
- 图像处理之图像格式变换和色彩增强---rgb2hsi2hsv 色彩增强
从昨天折腾到今天.再折腾下去我都要上主楼了 大致和灰度图均衡是一样的,主要是不能像平滑什么的直接对R,G,B三个分量进行.这样出来的图像时没法看的.因此我们要对亮度进行均衡.而HSI彩色空间中的分量 ...
- Spring中的IOC容器(学习笔记)
如何将Bean配置到Spring的Bean容器中 通过xml配置文件: Bean实现类来自第三方类库:如“DataSource”等 需要命名空间配置如:context,aop,mvc等 ...
- 更多的使用自定义元素(CustomElement)。
更多的使用自定义元素(CustomElement).
- $.post 使用案例
$.post( aplnCommon.topUrl + 'ajaxLogin/ajaxLogin.action', { 'userLoginId' : userName, 'pwd' : userPw ...
- Java中数组复制的几种方式以及数组合并
1.Object.clone() 简单直接,只能对源数组完整地复制 2.Arrays.copyOf(T[] original, int newLength) 可以只复制源数组中部分元素,但复制的起始位 ...
- 恢复MySQL数据库删除的数据
在日常运维工作中,对于数据库的备份是至关重要的!数据库对于网站的重要性使得我们对 MySQL 数据库的管理不容有失!然而是人总难免会犯错误,说不定哪天大脑短路了,误操作把数据库给删除了,怎么办? 下面 ...
- devm_regmap_init_i2c【转】
本文转载自:http://blog.csdn.net/u011975319/article/details/52128845 本文有此处转载http://blog.csdn.net/luckywang ...
- 织梦dedecms如何显示所有文章列表
本文介绍了dedecms中显示所有文章列表的实现方法,dedecms如何显示所有文章列表,有需要的朋友参考下. 例子,dedecms中显示所有文章列表. 代码示例:{dede:channelart ...