[板子]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 硬件工程师在做 ...
随机推荐
- springboot+swagger2
springboot+swagger2 小序 新公司的第二个项目,是一个配置管理终端机(比如:自动售卖机,银行取款机)的web项目,之前写过一个分模块的springboot框架,就在那个框架基础上进行 ...
- MongoDB的备份和部署 高级功能索引,聚合复制,分片
创建备份 MongoDB 数据转储 为了在 MongoDB 中创建数据库备份,需要使用 mongodump 命令.该命令会将服务器上的所有数据都转储到 dump 目录中.你可以使用很多选项来限制转储的 ...
- 基于注解方式实现Aop
开启注解扫描 <context:component-scan base-package="aopSpring"></context:component-scan& ...
- CSS1-3基礎知識
CSS1-3基礎知識 1.css排版 css在html內排版: <style type='text/css'> 標記名{} .類型名{} #ID名{} 標記名,.類型名,#ID名{} &l ...
- Linux(centos)环境下Lamp环境搭建,成功版。
搭建环境必须条件:1.Linux环境,2.Apache,3.mysql ,4.PHP,搭建步骤如下 1.开启Linux,得到root权限:sudo su 接下来输入登录密码,进入root权限,因为安装 ...
- Highway Networks
一 .Highway Networks 与 Deep Networks 的关系 深层神经网络相比于浅层神经网络具有更好的效果,在很多方面都已经取得了很好的效果,特别是在图像处理方面已经取得了很大的突破 ...
- 修改Form ->Top和Left 造成的莫名其妙的显示异常 “轴信息”
相关代码: 运行程序: 要等待很久,或者把主窗体最小化,再最大化打开"轴信息" 才会恢复正常. 这个"不爽"很蛋蛋 ,网友亲亲们,有独到见解的亲亲们,期待得到你 ...
- 插入排序的性能测试对比(C与C++实现)
一.概述: [标题]学生成绩管理的设计与实现 [开发语言]C.C++ [主要技术]结构体.STL [基本功能]实现对学生成绩类的基本操作:增加.删除.查询.排序 [测试数据]功能测试:按提示输入5组正 ...
- java数据库编程之DAO模式
第八章:DAO模式 8.1:JDBC封装 为了提高代码的维护性和扩展性,我们使用JDBC进行封装数据, 先定义统一的API,将操作数据的代码抽象到接口中,业务逻辑代码只需要调用这些接口的实现类的对象, ...
- dos攻击命令
net user //查看有哪些用户 net start //查看开启了哪些服务项目 net send ip "文本信息" //向对方发送消息(如果对方关了信使有可能会收不到) n ...