备战蓝桥杯 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

相关推荐
小龙报14 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 1.移动零,2.颜色分类
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
再睡一夏就好14 小时前
【C++闯关笔记】使用红黑树简单模拟实现map与set
java·c语言·数据结构·c++·笔记·语法·1024程序员节
im_AMBER14 小时前
Leetcode 43
笔记·学习·算法·leetcode
ceffans15 小时前
PDF文档中表格以及形状解析-后续处理(线段生成最小多边形)
c++·windows·算法·pdf
mifengxing15 小时前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
魔云连洲16 小时前
前端树形结构过滤算法
前端·算法
小龙报16 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 询问学号,寄包柜,合并两个有序数组
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
序属秋秋秋16 小时前
《Linux系统编程之开发工具》【编译器 + 自动化构建器】
linux·运维·服务器·c语言·c++·自动化·编译器
夏玉林的学习之路17 小时前
正则表达式
数据库·c++·qt·mysql·正则表达式
小南家的青蛙17 小时前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展