备战蓝桥杯 Day4 差分

差分(修改区间后查询)

1.要点

复制代码
a[0]=0;
for(int i=1;i<=n;i++){
	diff[i]=a[i]-a[i-1];//构建差分数组
}
//原数组a区间[l,r]全部加上x
diff[l]+=x;//还原a数组[l,n]全部加上x
diff[r+1]-=x;//还原a数组[r+1,n]全部减去x
for(int i=1;i<=n;i++){
	a[i]=a[i-1]+diff[i];
}

实现多次修改完后多次查询 ,不能实现边修改边查询

2.例题

2022重新排序

利用差分+1-1获得数组每个位置的查询次数(可简化为一个数组),而查询次数*数字=总和 ,要排序只需原数组和查询次数数组均升序即可实现数字越大 ,查询次数越大,再利用查询次数*数字=总和,只不过第一次可以利用前缀和

复制代码
#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
const int N=1e5+9;
ll a[N],b[N],bdiff[N];//b[N]为位置查询次数数组.bdiff[N]为位置查询次数差分数组 
 
int main(){
	ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	int m;
	cin>>m;
	ll res=0,sumA=0,sumB=0;
	while(m--){
		ll l,r;
		cin>>l>>r;
		bdiff[l]+=1;
		bdiff[r+1]-=1;
	}
	for(int i=1;i<=n;i++){
		b[i]=b[i-1]+bdiff[i];//b[i]为每个位置查询次数 
	}
	for(int i=1;i<=n;i++){
		sumA+=a[i]*b[i];//查询次数*数字=总和 
	}
	sort(a+1,a+1+n),sort(b+1,b+1+n);//两个数组均排序就能实现大数字在次数高位
	for(int i=1;i<=n;i++){
		sumB+=a[i]*b[i];
	} 
	res=sumB-sumA;
	cout<<res;
	return 0;
}

2018三体攻击

三维差分太困难,目前先不纠结,之后遇到太难的题目不要浪费时间,暴力拿分跳过,此题学习到:

1.三维数组不能开太大,否则编译不通过,可以第一维开3000,后两维开200

2.多层for中直接退出先输出答案然后exit(0),不用break

相关推荐
smj2302_7968265215 小时前
解决leetcode第3934题最短唯一子数组
数据结构·python·算法·leetcode
NashSKY15 小时前
EPnP 算法详解
算法·矩阵分解·多视图几何·射影几何
小O的算法实验室15 小时前
2026年SEVC,自适应模因算法+复杂约束条件下多无人机协同任务分配,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
iiiiyu15 小时前
面向对象和集合编程题
java·开发语言·前端·数据结构·算法·编程语言
xiaoxiaoxiaolll15 小时前
Light首次发表:动量空间穆勒矩阵偏振测量,破解纳米手性结构表征难题
人工智能·算法
变量未定义~15 小时前
最长回文子串
数据结构·算法
会周易的程序员16 小时前
aiDgeScanner:工业设备扫描与管理的一体化利器——深度解析上位机与扫描端的无缝协作
c++·物联网·typescript·electron·vue·iot·aiot
BirdenT16 小时前
20260518紫题训练
c++·算法
玛卡巴卡ldf17 小时前
【LeetCode 手撕算法】(多维动态规划)不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离
java·数据结构·算法·leetcode·动态规划·力扣
被AI抢饭碗的人17 小时前
算法:数据结构
数据结构·算法