洛谷 P3372 线段树1
这是一道模板题
线段树介绍https://www.cnblogs.com/nvwang123/p/10420832.html
#include<bits/stdc++.h>
using namespace std;
int m,n;
int a[]; struct node{
int l,r;
long long w,f; //w是区间值,f是懒标记
}xds[*]; //4倍空间 //一、建树
void buid(int l,int r,int k){
xds[k].l=l;
xds[k].r=r;
if(l==r){
xds[k].w=a[l]; // 最底层的区间从左边开始是1,所以可以这样
return;
}
int m=(l+r)/;
buid(l,m,*k);
buid(m+,r,*k+);
xds[k].w=xds[*k].w+xds[*k+].w;//不要忘记区间和上传!!特别容易忘
} //二、懒标记下传
void down(int k){
xds[*k].w+=xds[k].f*(xds[*k].r-xds[*k].l+);
xds[*k+].w+=xds[k].f*(xds[*k+].r-xds[*k+].l+);
xds[*k].f+=xds[k].f;
xds[*k+].f+=xds[k].f;
xds[k].f=;//易漏
} //三、区间修改
void add_(int x,int y,int k,int a){
if(xds[a].l>=x&&xds[a].r<=y){
xds[a].w+=(long long)k*(xds[a].r-xds[a].l+);
xds[a].f+=k; //易漏 ,记得做懒标记
return;
}
if(xds[a].f) down(a);//!!!
int m=(xds[a].l+xds[a].r)/;
if(x<=m) add_(x,y,k,a*);
if(y>m) add_(x,y,k,a*+);
xds[a].w=xds[a*].w+xds[a*+].w;
} long long ask_(int x,int y,int k) //注意数据范围内,开int只能得70分
{
if (xds[k].l>=x&&xds[k].r<=y)
return xds[k].w; if(xds[k].f) down(k); int m=(xds[k].l+xds[k].r)/;
long long ans=;
if(x<=m) ans+=ask_(x,y,k*);
if(y>m) ans+=ask_(x,y,k*+);
return ans;
} int main(){
cin>>n>>m; for(int i=;i<=n;i++) cin>>a[i];
buid(,n,); for(int i=;i<=m;i++){
int a,x,y,k;
cin>>a;
if(a==) cin>>x>>y>>k,add_(x,y,k,);
if(a==) cin>>x>>y,cout<<ask_(x,y,)<<endl;
}
return ;
}
洛谷 P3372 线段树1的更多相关文章
- 洛谷P3372线段树模板1——线段树
题目:https://www.luogu.org/problemnew/show/P3372 线段树模板. 代码如下: #include<iostream> #include<cst ...
- 洛谷P3372线段树1
难以平复鸡冻的心情,虽然可能在大佬眼里这是水题,但对蒟蒻的我来说这是个巨大的突破(谢谢我最亲爱的lp陪我写完,给我力量).网上关于线段树的题解都很玄学,包括李煜东的<算法竞赛进阶指南>中的 ...
- NOIP2017提高组Day2T3 列队 洛谷P3960 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/9265380.html 题目传送门 - 洛谷P3960 题目传送门 - LOJ#2319 题目传送门 - Vij ...
- 洛谷P3373线段树模板2
题目:https://www.luogu.org/problemnew/show/P3373 带乘的线段树,更新时把加的标记也乘一下,然后取值时先乘后加. 代码如下: #include<iost ...
- 洛谷P3373 线段树2(补上注释了)
毒瘤题.找了一下午+晚上的BUG,才发现原来query_tree写的是a%p; 真的是一个教训 UPD:2019.6.18 #include<iostream> #include<c ...
- 洛谷3372线段树模板题 对区间+k或者查询区间和
#include<bits/stdc++.h> using namespace std; typedef unsigned int ui; typedef long long ll; ty ...
- 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)
洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...
- 洛谷1087 FBI树 解题报告
洛谷1087 FBI树 本题地址:http://www.luogu.org/problem/show?pid=1087 题目描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全 ...
- 洛谷P3018 [USACO11MAR]树装饰Tree Decoration
洛谷P3018 [USACO11MAR]树装饰Tree Decoration树形DP 因为要求最小,我们就贪心地用每个子树中的最小cost来支付就行了 #include <bits/stdc++ ...
随机推荐
- 关于Vim 的插件snipmate 以及它的安装方式
在网上看了http://study.163.com/course/courseMain.htm?courseId=269016#/courseMain 里关于snipmate 的视频 snipma ...
- 《JavaScript高级程序设计》第5章 Object类型---Array---学习心得
1.创建数组的方法: 使用Array构造函数: var colors=new Array() var colors=new Array(20)//l创建一个包含20项的数组 var colors=ne ...
- [PHP]memcache安装
1.memcached 安装sudo apt-get install memcached memcached 参数说明memcached -d -m 50 -p 11211 -u root-m 指定使 ...
- React.js 小书 Lesson5 - React.js 基本环境安装
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson5 转载请注明出处,保留原文链接和作者信息. 安装 React.js React.js 单独使 ...
- [Maven] Project build error: 'packaging' with value 'jar' is invalid. Aggregator projects require 'pom' as packaging.
将<packaging>jar</packaging> 改为<packaging>pom</packaging>
- logback配置说明
我觉得对于logback大家不太明白的有:过滤器.logger和root以及其中的一些属性的关系.其他的应该不是多迷糊,所以我就主要说说这几个的关系,并且为了清晰我只说控制台日志,写到文件的日志配置大 ...
- laravel安装时openssl_encrypt() 的问题?Call to undefined function openssl_decrypt()
解决方案: 如果通过上面的步骤还是不能解决参考如下: 1.从php安装根目录中拷贝 libeay32.dll 和 ssleay32.dll 然后 覆盖掉apache/bin 下的对应文件(注意需要将h ...
- Cocos2D-HTML5 Android项目编译
首先要有 Eclipse 和 ADT.CDT.Android SDK.Android NDK.新建一个文件MoonWar_Apk.cmd,将以下代码拷贝其中,双击之即可. set EngineHome ...
- 聪明的Azure CDN,帮你找到云端捷径
你知道吗?身处上海和纽约的两个用户同时通过网络收看“春晚”直播,纽约播放得可能比上海还要更流畅,这当然不是因为纽约距离北京的直播机房更近或者网速更快,而是因为大年夜在大洋彼岸围观“春晚”的观众相对较少 ...
- DB2安装教程图解
下载好之后,是exe文件,但是双击后基本上都是解压,但是使用自身的解压的话会有很多文件解压失败的情况,所以推荐使用自己电脑上自带的解压工具直接解压(如360解压,好压等). 解压之后直接运行setup ...