算法模板-线段树

线段树

模板

(P3372 【模板】线段树 1)[https://www.luogu.com.cn/problem/P3372\]

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cmath>
#include<cstring>
typedef long long ll;
using namespace std;
const int N=100010;
struct node{
	int l,r;
	ll sum,add;
}tr[N*4];
int n,m;
int w[N];

void pushup(int u){
	tr[u].sum=tr[u<<1].sum+tr[u<<1|1].sum;
}

void pushdown(int u){
	node &root=tr[u],&left=tr[u<<1],&right=tr[u<<1|1];
	if (root.add){
		left.add+=root.add; left.sum+=(ll)(left.r-left.l+1)*root.add;
		right.add+=root.add; right.sum+=(ll)(right.r-right.l+1)*root.add;
		root.add=0;
	}
}
void modify(int u,int l,int r,int d){
	if (tr[u].l>=l&&tr[u].r<=r) {
		tr[u].sum+=(ll)(tr[u].r-tr[u].l+1)*d;
		tr[u].add+=d;
	}
	else {
		pushdown(u);
		int mid=tr[u].l+tr[u].r>>1;
		if (l<=mid) modify(u<<1,l,r,d);
		if (r>mid) modify(u<<1|1,l,r,d);
		pushup(u);
		
	}
}
void build (int u,int l,int r){
	if (l==r) tr[u]={l,r,w[r],0};
	else{
		tr[u]={l,r};
		int mid=l+r>>1;
		build (u<<1,l,mid);
		build (u<<1|1,mid+1,r);
		pushup(u);
	}
}
ll query(int u,int l,int r){
	if (tr[u].l>=l&&tr[u].r<=r) return tr[u].sum;
	pushdown(u);
	int mid=tr[u].l+tr[u].r>>1;
	ll sum=0;
	if (l<=mid )sum+=query(u<<1,l,r);
	if (r>mid) sum+=query(u<<1|1,l,r);
	return sum;
}

int main(){
	cin>>n>>m;
	for (int i=1;i<=n;i++){
		cin>>w[i];
	}
	build (1,1,n);
	for (int i=1;i<=m;i++){
		int a,b,c,d;
		cin>>a>>b>>c;
		if (a==1){
			cin>>d;
			modify(1,b,c,d);
		}
		else{
			cout<<query(1,b,c)<<endl;
		}
			
	}
	return 0;
}
相关推荐
张李浩3 小时前
Leetcode 054螺旋矩阵 采用方向数组解决
算法·leetcode·矩阵
big_rabbit05023 小时前
[算法][力扣101]对称二叉树
数据结构·算法·leetcode
美好的事情能不能发生在我身上3 小时前
Hot100中的:贪心专题
java·数据结构·算法
myloveasuka3 小时前
Java与C++多态访问成员变量/方法 对比
java·开发语言·c++
2301_821700534 小时前
C++编译期多态实现
开发语言·c++·算法
奥地利落榜美术生灬4 小时前
c++ 锁相关(mutex 等)
开发语言·c++
xixihaha13244 小时前
C++与FPGA协同设计
开发语言·c++·算法
小小怪7504 小时前
C++中的函数式编程
开发语言·c++·算法
xixixiLucky4 小时前
编程入门算法题---小明爬楼梯求爬n层台阶一共多少种方法
算法
剑锋所指,所向披靡!5 小时前
数据结构之线性表
数据结构·算法