这是一道模板题

线段树介绍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的更多相关文章

  1. 洛谷P3372线段树模板1——线段树

    题目:https://www.luogu.org/problemnew/show/P3372 线段树模板. 代码如下: #include<iostream> #include<cst ...

  2. 洛谷P3372线段树1

    难以平复鸡冻的心情,虽然可能在大佬眼里这是水题,但对蒟蒻的我来说这是个巨大的突破(谢谢我最亲爱的lp陪我写完,给我力量).网上关于线段树的题解都很玄学,包括李煜东的<算法竞赛进阶指南>中的 ...

  3. NOIP2017提高组Day2T3 列队 洛谷P3960 线段树

    原文链接https://www.cnblogs.com/zhouzhendong/p/9265380.html 题目传送门 - 洛谷P3960 题目传送门 - LOJ#2319 题目传送门 - Vij ...

  4. 洛谷P3373线段树模板2

    题目:https://www.luogu.org/problemnew/show/P3373 带乘的线段树,更新时把加的标记也乘一下,然后取值时先乘后加. 代码如下: #include<iost ...

  5. 洛谷P3373 线段树2(补上注释了)

    毒瘤题.找了一下午+晚上的BUG,才发现原来query_tree写的是a%p; 真的是一个教训 UPD:2019.6.18 #include<iostream> #include<c ...

  6. 洛谷3372线段树模板题 对区间+k或者查询区间和

    #include<bits/stdc++.h> using namespace std; typedef unsigned int ui; typedef long long ll; ty ...

  7. 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)

    洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...

  8. 洛谷1087 FBI树 解题报告

    洛谷1087 FBI树 本题地址:http://www.luogu.org/problem/show?pid=1087 题目描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全 ...

  9. 洛谷P3018 [USACO11MAR]树装饰Tree Decoration

    洛谷P3018 [USACO11MAR]树装饰Tree Decoration树形DP 因为要求最小,我们就贪心地用每个子树中的最小cost来支付就行了 #include <bits/stdc++ ...

随机推荐

  1. HIbernate基于外键的查询

    此文以个人开发记录为目的,笔拙勿喷 项目是背景是公司的E签宝平台VIP频道项目进行关联账户增加后,需要做删除时的,联合查询 当前主要表结构账户表Account. CREATE TABLE `accou ...

  2. 通用代码——makefile文件

    ver=debug ifeq ($(ver),debug) TARGET = testmain_d FLAG=-g -D debug else TARGET = testmain_r FLAG=-O3 ...

  3. 将php代码部署到新浪云测试(简单方法,包含数据库的连接)

    很多人做项目都是先在本地测试然后上传到服务器运行,如果包含了操作数据库的信息往往需要进行一番调试,这里我总结一下把php代码包含数据库的连接如何上传到新浪云服务器的步骤. 1.在新浪云应用SAE的控制 ...

  4. 在thinkpad SL400上U盘安装双系统ubuntu14.10

    转自:http://zydky.iteye.com/blog/1674100 上文中装的双系统是centos6.3,因为自己对ubuntu有点熟悉,就装了ubuntu. 笔记本是09年入手的,买了之后 ...

  5. vue2 关于ref

    1,VUE2子组件索引 <div id="app"> <navbar></navbar> <pagefooter></page ...

  6. 解决Pandoc wasn't found.pdflatex not found on PATH

    解决nbconvert failed: Pandoc wasn't found.解决nbconvert failed: pdflatex not found on PATH 问题1描述 500 : I ...

  7. iDempiere 使用指南 BOM及工单流程

    Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...

  8. Java Knowledge series 7

    Pepole who make a greate contribution on common libaraies deserve our respect. Component(Widget) / S ...

  9. Linux,MD5

    Linux 中的 md5 利用 md5 消息摘要算法可以获取任何一件事物的唯一 ID 利用 md5 消息摘要算法可以判断任何一个事物是否被改变过 一致性验证:MD5的典型应用是对一段信息(Messag ...

  10. CRM的划分

          CRM提供完整的客户生命周期管理解决方案,帮助您管理各项与客户有关的事件,包括市场.销售以及客户支持等方面,优化事件处理流程,从而赢得更多客户,并提高客户满意度.   按企业经营类型划分 ...