分块维护和板子

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
using ll = long long;
ll s[N];
ll b[N];
ll w[N];
ll add[N];
int l[N],r[N];
int tot,n,len,q;
int belong[N];


inline void init()
{
	len = sqrt(n),tot = (n+len-1)/len;
	for(int i=1;i<=tot;i++)
	 l[i] = r[i-1]+1,r[i] = i*len;
	 
	for(int i=1;i<=tot;i++){
		for(int j=l[i];j<=r[i];j++)
		 b[i]+=w[j],belong[j] = i;
		s[i] = s[i-1] + b[i];
	}
	
}

inline void modify(int ql,int qr,int c){
	int p = belong[ql],q = belong[qr];
	if(p==q){
		for(int i=ql;i<=qr;i++)w[i]+=c,b[p]+=c;
		for(int i=p;i<=tot;i++)s[i] = s[i-1]+b[i];
		return;
	}
	
	for(int i=ql;i<=r[p];i++)w[i]+=c,b[p]+=c;
	for(int i=qr;i>=l[q];--i)w[i]+=c,b[q]+=c;
	for(int i=p+1;i<=q-1;i++)add[i]+=c,b[i]+=(ll)(r[i]-l[i]+1)*c;
	
	for(int i=p;i<=tot;i++)s[i] = s[i-1]+b[i];
}



inline ll query(int ql,int qr){
	int p = belong[ql],q = belong[qr];
	ll res = 0;
	if(p==q){
		for(int i=ql;i<=qr;i++)res+=w[i]+add[p];
		return res;
	}
	
	res = s[q-1]-s[p];
	for(int i=ql;i<=r[p];++i)res+=w[i]+add[p];
	for(int i=qr;i>=l[q];--i)res+=w[i]+add[q];
	return res;
}



int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>q;
	for(int i=1;i<=n;i++)cin>>w[i];
	init();
	while(q--){
		int op,ql,qr;cin>>op>>ql>>qr;
		if(op==1){
			int c;
			cin>>c;modify(ql,qr,c);
		}
		else cout<<query(ql,qr)<<"\n";
	}
}
相关推荐
电鱼智能的电小鱼2 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun3 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书4 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
yuuki2332334 小时前
【数据结构】用顺序表实现通讯录
c语言·数据结构·后端
DashVector5 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会5 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗5 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚5 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实5 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证7 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型