算法模板-线段树

线段树

模板

(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;
}
相关推荐
枫叶林FYL15 小时前
第9章 因果推理与物理理解
人工智能·算法·机器学习
Tanecious.15 小时前
蓝桥杯备赛:Day5-P1706 全排列问题
c++·蓝桥杯
胖咕噜的稞达鸭15 小时前
C++技术岗面试经验总结
开发语言·网络·c++·网络协议·tcp/ip·面试
Wild_Pointer.15 小时前
高效工具实战指南:从零开始编写CMakeLists
c++
小白zlm15 小时前
预畸变双线性变换
单片机·嵌入式硬件·算法·电机控制
wuweijianlove16 小时前
算法复杂度估算的实验建模与可视化表达的技术6
算法
执笔画流年呀16 小时前
7大排序算法
java·算法·排序算法
AI成长日志16 小时前
【算法学习专栏】动态规划基础·中等两题精讲(198.打家劫舍、322.零钱兑换)
学习·算法·动态规划
计算机安禾16 小时前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio
测试_AI_一辰16 小时前
AI 如何参与 Playwright 自动化维护:一次自动修复闭环实践
人工智能·算法·ai·自动化·ai编程