[板子]segTree
segTree
参考:http://www.cnblogs.com/TenosDoIt/p/3453089.html#c
初学者建议先参考上面“一步一步理解线段树”学习理论。
在这里Code分别为区间求和&区间求积的做法。
分别对应OJ luogu的3372和3373
1.区间和
#include<cstdio> #include<cmath> #include<iostream> #include<algorithm> using namespace std; struct node{ long long val,lazytag; }segTree[*+]; ]; int n,m,t,x,y,k; void build(int root,long long arr[],int istart,int iend){//建树 segTree[root].lazytag=; if(istart==iend){ segTree[root].val=arr[istart]; }else{ ; build(root*,arr,istart,mid); build(root*+,arr,mid+,iend); segTree[root].val=segTree[root*].val+segTree[root*+].val; } } void pushDown(int root,int start,int end){//插入懒标记 ){ segTree[root*].lazytag+=segTree[root].lazytag; segTree[root*+].lazytag+=segTree[root].lazytag; ; segTree[root*].val+=segTree[root].lazytag*(mid-start+); segTree[root*+].val+=segTree[root].lazytag*(end-mid); segTree[root].lazytag=; } } long long query(int root,int nstart,int nend,int qstart,int qend){//查询区间 if(qstart>nend||qend<nstart){ ; }if(qstart<=nstart&&qend>=nend){ return segTree[root].val; } pushDown(root,nstart,nend); ; ,nstart,mid,qstart,qend)+query(root*+,mid+,nend,qstart,qend); } void update(int root,int nstart,int nend,int ustart,int uend,int addval){//赋值 if(ustart>nend||uend<nstart){ return; }if(ustart<=nstart&&uend>=nend){ segTree[root].lazytag+=addval; segTree[root].val+=addval*(nend-nstart+); return; } pushDown(root,nstart,nend); ; update(root*,nstart,mid,ustart,uend,addval); update(root*+,mid+,nend,ustart,uend,addval); segTree[root].val=segTree[root*].val+segTree[root*+].val; } int main(){ scanf("%lld%lld",&n,&m); ;i<=n;i++){ scanf("%lld",&a[i]); } build(,a,,n); ;i<=m;i++){ scanf("%lld",&t); ){ scanf("%lld%lld%lld",&x,&y,&k); update(,,n,x,y,k); }){ scanf("%lld%lld",&x,&y); printf(,,n,x,y)); } } }
2.区间积
在这里要点几个点注意:
1:tag2的初始值为1;
2:pushdown里先tag2后tag1(先乘后加);
3:对tag2进行push需要先把tag1*tag2,tag2*tag2,val*tag2,最后别忘了tag2=1;
4:tag2不需要乘区间,原因是:a*(b+c)=a*b+a*c,乘法分配律;
#include<cstdio> #include<cmath> #include<iostream> #include<algorithm> using namespace std; struct node{ long long val,lazytag,lazytag2; }segTree[*+]; ]; long long n,m,t,x,y,k,p; void build(int root,long long arr[],int istart,int iend){//建树 segTree[root].lazytag=; segTree[root].lazytag2=; if(istart==iend){ segTree[root].val=arr[istart]; }else{ ; build(root*,arr,istart,mid); build(root*+,arr,mid+,iend); segTree[root].val=segTree[root*].val+segTree[root*+].val; } } void pushDown(int root,int start,int end){//插入懒标记 **){** segTree[root*].lazytag=(segTree[root*].lazytag*segTree[root].lazytag2)%p; segTree[root*+].lazytag=(segTree[root*+].lazytag*segTree[root].lazytag2)%p; segTree[root*].lazytag2=(segTree[root*].lazytag2*segTree[root].lazytag2)%p; segTree[root*+].lazytag2=(segTree[root*+].lazytag2*segTree[root].lazytag2)%p; ; segTree[root*].val=(segTree[root*].val*(segTree[root].lazytag2))%p; segTree[root*+].val=(segTree[root*+].val*(segTree[root].lazytag2))%p; segTree[root].lazytag2=; } ){ segTree[root*].lazytag+=segTree[root].lazytag; segTree[root*+].lazytag+=segTree[root].lazytag; ; segTree[root*].val+=segTree[root].lazytag*(mid-start+); segTree[root*+].val+=segTree[root].lazytag*(end-mid); segTree[root].lazytag=; } } long long query(int root,int nstart,int nend,int qstart,int qend){//查询区间 if(qstart>nend||qend<nstart){ ; }if(qstart<=nstart&&qend>=nend){ return segTree[root].val; } pushDown(root,nstart,nend); ; ,nstart,mid,qstart,qend)+query(root*+,mid+,nend,qstart,qend); } void update(int root,int nstart,int nend,int ustart,int uend,int addval){//赋值 if(ustart>nend||uend<nstart){ return; }if(ustart<=nstart&&uend>=nend){ segTree[root].lazytag+=addval; segTree[root].val+=addval*(nend-nstart+); return; } pushDown(root,nstart,nend); ; update(root*,nstart,mid,ustart,uend,addval); update(root*+,mid+,nend,ustart,uend,addval); segTree[root].val=segTree[root*].val+segTree[root*+].val; } **void tupdate(int root,int nstart,int nend,int ustart,int uend,int addval){//赋值(chengfa** if(ustart>nend||uend<nstart){ return; }if(ustart<=nstart&&uend>=nend){ segTree[root].lazytag=(segTree[root].lazytag*addval)%p; segTree[root].lazytag2=(segTree[root].lazytag2*addval)%p; segTree[root].val=(segTree[root].val*addval)%p; return; } pushDown(root,nstart,nend); ; tupdate(root*,nstart,mid,ustart,uend,addval); tupdate(root*+,mid+,nend,ustart,uend,addval); segTree[root].val=segTree[root*].val+segTree[root*+].val; } int main(){ scanf("%lld%lld%lld",&n,&m,&p); ;i<=n;i++){ scanf("%lld",&a[i]); } build(,a,,n); ;i<=m;i++){ scanf("%lld",&t); ){ scanf("%lld%lld%lld",&x,&y,&k); update(,,n,x,y,k); }){ scanf("%lld%lld",&x,&y); printf(,,n,x,y)%p); }){ scanf("%lld%lld%lld",&x,&y,&k); tupdate(,,n,x,y,k); } } ; }
并且感谢will7101的帮助
[板子]segTree的更多相关文章
- [板子]最小费用最大流(Dijkstra增广)
最小费用最大流板子,没有压行.利用重标号让边权非负,用Dijkstra进行增广,在理论和实际上都比SPFA增广快得多.教程略去.转载请随意. #include <cstdio> #incl ...
- [板子]ISAP
ISAP求最大流,敲了一发板子,无压行,教程略去.转载请随意. #include <cstdio> #include <cstring> #include <algori ...
- [板子]倍增LCA
倍增LCA板子,没有压行,可读性应该还可以.转载请随意. #include <cstdio> #include <cstring> #include <algorithm ...
- UP Board 人若有大胆,板子就很惨:首次上电开机失败
前言 原创文章,转载引用务必注明链接. 注意:拍照自带抖动功能,画质大家凑合着看.冬日天气干燥,手触摸板子前建议流水洗手或者握持大体积导电体将静电放走. 本文使用Markdown写成,为获得更好的阅读 ...
- orpsocv2 从ROM(bootrom)启动分析--以atlys板子的启动为例子
1 复位后的启动地址 1) 复位后,启动地址在or1200_defines.v最后宏定义,atlys板子的目录:orpsocv2\boards\xilinx\atlys\rtl\verilog\inc ...
- Lattice FPGA 板子 调试笔记
最近在调试LATTICE FPGA 做的视频板子,颇不顺利,所以记录下来作为以后的参考: 1.FPGA的IO口不是所有的都是双向的,有些有特殊作用的是单向的. 在查阅 LatticeECP3-17E ...
- 【图像处理】【SEED-VPM】1.板子基本操作流程
>>>>>>>>>>>>>>>>>>>>>>>>> ...
- NFS 网络文件系统挂载在A8板子上
我承认自己是菜鸟,没什么网络知识就来搞挂载nfs网络文件系统,花费了5天的时间才把nfs网络文件系统成功挂载在A8板子上,实现了A8板子和虚拟机的文件共享.分享一下个人经验: 以下是基于nfs已经完成 ...
- [PCB设计] 2、畸形PCB板子的制作核心——AD14导入dwg格式文件的方法
本文参考园友:The Zone of up.Craftor http://www.cnblogs.com/craftor/archive/2012/06/28/2567259.html 硬件工程师在做 ...
随机推荐
- java GUI编程二
java基础学习总结--GUI编程(二) 一.事件监听 测试代码一: 1 package cn.javastudy.summary; 2 3 import java.awt.*; 4 import j ...
- java 对象转型
一.对象转型介绍 对象转型分为两种:一种叫向上转型(父类对象的引用或者叫基类对象的引用指向子类对象,这就是向上转型),另一种叫向下转型.转型的意思是:如把float类型转成int类型,把double类 ...
- easyui动态生成列
需求:一个id对应多个key value 将id作为标识列 key值作为表头 value作为值显示.数据表可分为两张表 param数据表: 下表一个id对应上表多个key及value 如下图 id_p ...
- 深入理解计算机系统chapter3
栈在处理过程调用中起到至关重要的作用,栈向下增长,栈顶元素的地址是所有栈中元素最小的.栈指针%esp保存着栈顶元素的地址 控制: 重点: 基于条件数据传送的代码比基于条件控制转移(预测错误惩罚比较高) ...
- ASP.NET Core 2.0 使用支付宝PC网站支付
前言 最近在使用ASP.NET Core来进行开发,刚好有个接入支付宝支付的需求,百度了一下没找到相关的资料,看了官方的SDK以及Demo都还是.NET Framework的,所以就先根据官方SDK的 ...
- MySQL主从同步和读写分离的配置
主服务器:192.168.1.126 从服务器:192.168.1.163 amoeba代理服务器:192.168.1.237 系统全部是CentOS 6.7 1.配置主从同步 1.1.修改主服务器( ...
- uva1267 Network
https://vjudge.net/problem/UVA-1267 题意: 有一棵树,上面有一个放着水源的点s,给出一个数k,这个水源可以覆盖路径长度到s不超过k的叶子节点.现在需要把所有的叶子节 ...
- 零复制(zero copy)技术
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Java并发/多线程系列——初识篇
回到过去,电脑有一个CPU,一次只能执行一个程序.后来多任务处理意味着计算机可以同时执行多个程序(AKA任务或进程).这不是真的"同时".单个CPU在程序之间共享.操作系统将在运行 ...
- 一文为你详细讲解对象映射库【AutoMapper】所支持场景
前言 在AutoMapper未出世前,对象与对象之间的映射,我们只能通过手动为每个属性一一赋值,时间长了不仅是我们而且老外也觉得映射代码很无聊啊.这个时候老外的所写的强大映射库AutoMapper横空 ...