线段树成段更新模板POJ3468 zkw以及lazy思想
别人树状数组跑几百毫秒 我跑 2500多
#include<cstdio>
#include<map>
//#include<bits/stdc++.h>
#include<vector>
#include<stack>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<cstdlib>
#include<climits>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
typedef __int64 int64;
const ll mood=1e9+;
const int64 Mod=;
const double eps=1e-;
const int MAXN=;
const double PI=acos(-1.0);
inline void rl(ll&num){
num=;ll f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='')num=num*+ch-'',ch=getchar();
num*=f;
}
inline void ri(int &num){
num=;int f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='')num=num*+ch-'',ch=getchar();
num*=f;
}
int getnum()//相邻的个位整数输入 如想分别保存1234 输入连续的1234 a[i]=getnum();就可以实现
{
char ch=getchar();
while((ch<'' || ch>'') && ch!='-')
ch=getchar();
return (ch-'');
}
inline void out(int x){ if(x<) {putchar('-'); x*=-;}if(x>) out(x/); putchar(x%+''); }
ll sum[MAXN<<],add[MAXN<<];
int n;
void init(int _n)
{
n=;
while(n<_n) n*=;
for(int i=;i<*n-;i++)
{
sum[i]=add[i]=;
}
}
void pushdown(int rt,int m)
{
if(add[rt])
{
add[rt*+] += add[rt];
add[rt<<|] += add[rt];
sum[rt*+] += add[rt] * (m - (m>>));
sum[rt<<|] += add[rt] * (m>>);
add[rt] = ;
}
}
void pushup(int rt)
{
sum[rt]=sum[rt*+]+sum[rt<<|];
}
void update(int a,int b,int c,int k,int l,int r)
{
if(r<=a||b<=l) return ;
if(a<=l&&r<=b)
{
add[k]+=c;
sum[k]+=(ll)c*(r-l);
return ;
}
if(l+==r) return;
pushdown(k,r-l);
int m=(l+r)/;
if(b<=m)
{
update(a,b,c,k*+,l,m);
}
else{
if(l>m)update(a,b,c,k*+,m,r);
else{
update(a,b,c,k*+,l,m);
update(a,b,c,k*+,m,r);
}
}
pushup(k);
}
ll query(int a,int b,int k,int l,int r)
{
if(r<=a||b<=l) return ;
if(a<=l&&r<=b)
{
return sum[k];
}
pushdown(k,r-l);
int m=(l+r)/;
ll res=;
if(b<=m)
{
res+=query(a,b,k*+,l,m);
}
else{
if(l>m)res+=query(a,b,k*+,m,r);
else{
res+=query(a,b,k*+,l,m);
res+=query(a,b,k*+,m,r);
}
}
return res;
}
void ad(int k,int a)
{
k+=n-;
sum[k]=a;
while(k>)
{
k=(k-)/;
sum[k]=sum[k*+]+sum[k*+];
}
}
int main()
{
int _n,m;
while(scanf("%d%d",&_n,&m)==)
{
init(_n);
for(int i=;i<=_n;i++)
{
int tem;
ri(tem);ad(i,tem);
}
char ch[]; int a,b,c;
while(m--)
{
scanf("%s",ch);
if(ch[] == 'Q')
{
scanf("%d %d", &a,&b);
printf("%lld\n",query(a,b+,,,n));
} else
{
scanf("%d %d %d",&a,&b,&c);
update(a,b+,c,,,n);
}
}
memset(add,,sizeof(add));
memset(sum,,sizeof(sum));
}
return ;
}
等看能不能优化再写
线段树成段更新模板POJ3468 zkw以及lazy思想的更多相关文章
- 【线段树成段更新-模板】【HDU1698】Just a Hook
		
题意 Q个操作,将l,r 的值改为w 问最后1,n的sum 为多少 成段更新(通常这对初学者来说是一道坎),需要用到延迟标记(或者说懒惰标记),简单来说就是每次更新的时候不要更新到底,用延迟标记使得更 ...
 - HDU-1698-Just a Hook-区间更新+线段树成段更新
		
In the game of DotA, Pudge’s meat hook is actually the most horrible thing for most of the heroes. T ...
 - 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. 这题 ...
 - 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 ...
 - HDU1698_Just a Hook(线段树/成段更新)
		
解题报告 题意: 原本区间1到n都是1,区间成段改变成一个值,求最后区间1到n的和. 思路: 线段树成段更新,区间去和. #include <iostream> #include < ...
 - HDU 3577 Fast Arrangement ( 线段树 成段更新 区间最值 区间最大覆盖次数 )
		
线段树成段更新+区间最值. 注意某人的乘车区间是[a, b-1],因为他在b站就下车了. #include <cstdio> #include <cstring> #inclu ...
 - poj 3468 A Simple Problem with Integers 【线段树-成段更新】
		
题目:id=3468" target="_blank">poj 3468 A Simple Problem with Integers 题意:给出n个数.两种操作 ...
 
随机推荐
- c/c++时间相关
			
本文从介绍基础概念入手,探讨了在C/C++中对日期和时间操作所用到的数据结构和函数,并对计时.时间的获取.时间的计算和显示格式等方面进行了阐述.本文还通过大量的实例向你展示了time.h头文件中声明的 ...
 - 洛谷 - P2281 - 多项式的加法和乘法 - 大模拟
			
题目链接:https://www.luogu.org/problemnew/show/P2281 题目的意思很简单,输入两个系数.指数都是整数,变量都是大写字母的多项式,求他们的加法结果和乘法结果. ...
 - E. Similarity of Subtrees【hash】
			
题意: 给你一棵树,问你有多少个组合的相似: 相似是a结点的子树和b结点的子树的每一层的结点数相等: 思路: HASH来搞: 主要也没学过散列表,以及一个散列函数的构造: 其实看下面程序很简单,手跑案 ...
 - APP为什么会被打回来??
			
APP的设置界面, 按钮使用了类似iPhone的操作方式以及icon的圆角设计 -> 重新设计 APP的年龄设置太低 -> 改年龄 APP里有实物奖励 -> 免责声明, ...
 - B - Dungeon Master POJ - 2251
			
//纯bfs #include <iostream> #include <algorithm> #include <cstring> #include <cs ...
 - [题解](次短路)luogu_P2865路障(未)
			
好像是个不需要vis数组的次短路,跑到收敛,然而给我脑袋弄炸了......到现在还没懂.......究竟次短路应该怎么求a...... 抄题解: #include<bits/stdc++.h&g ...
 - 洛谷 P3957 跳房子
			
https://www.luogu.org/problemnew/show/P3957 错误记录:1.没开longlong 2. -inf不够小 #include<cstdio> #inc ...
 - 118 Pascal's Triangle 帕斯卡三角形 杨辉三角形
			
给定 numRows, 生成帕斯卡三角形的前 numRows 行.例如, 给定 numRows = 5,返回[ [1], [1,1], [1,2,1], [1,3,3,1], [1 ...
 - keil_rtx特点
			
Keil RTX是一个专为ARM及Cortex M系列处理器开发的无版税的确定的实时操作系统.它允许工程师建立多任务同步并行的程序软件,同时也能帮助使程序代码更加结构化和便于维护. 产品亮点 所有 ...
 - POJ 1458    Common Subsequence DP
			
http://poj.org/problem?id=1458 用dp[i][j]表示处理到第1个字符的第i个,第二个字符的第j个时的最长LCS. 1.如果str[i] == sub[j],那么LCS长 ...