算法集训1:模拟,枚举,错误分析,前缀和,差分

枚举

一.比如:找到1-100最大质数

1.先对答案集合

如果范围集合找1-50中的数显然不对的

2.答案成立条件:结合题目的要求

3.尽可能减少枚举的范围,提高效率:枚举50-100的质数

4.选择合适的枚举顺序:

枚举质数,从1-100和从100-1是不一样的

前两种确定答案,后两种提高效率

枚举不一定要顺序循环枚举

二.搜索枚举:DFS BFS

比如:全排列:1-3的所有可能

三.模拟

题目告诉每一步的步骤

按照题目一步一步来,从家到学校到校门,题目咋说,咱们咋走

用算法的话,直接翻墙更近

难点:

题目简单,但是操作可能麻烦

不给直接的操作步骤,需要自己获取

错误分析

练习题

洛谷1003 1328

力扣59

四.前缀和

1.向上取整

整数除法想向上取整 → (被除数 + 除数 - 1)÷ 除数

// -1是为了不被整除,比如30/15=2,这时再加1就错误了

2. 向下取整(C++ 原生就是)

C++ 两个正整数相除,默认就是向下取整:

num = a / b

3.前缀和前提

数组均从下标1开始存储

a1--an

前缀和:数据前i项的和

1.一维数组:

2.二维数组

二维数组是:a11---aij的矩形区域

2.1二维数组的前提:

数组初始化为0,否则越界,下标必须从1开始

2.2二维前缀和公式

红色区域是蓝色和绿色的公共区域

计算最终结果,必须提前计算这三个数

2.3二维前缀和区间求和公式

二维前缀和求区间和(x,y)到(i,j)的和

高纬度的前缀和采取容斥原理的思想

2.4用法

前缀和一般是用来进行数组的预处理,提高后续操作效率的,多用于求区间和

五.差分

时间复杂度较高

接下来用差分(前缀和的逆运算)

一维公式:

a1=sum1

ai=sumi-sumi-1

图片是在L,R区间变化,aL+x时,想要把R后面的数不懂,所以aR+1-x

差分区间求值:

当前数组当作前缀和,求差分,差分改变之后,在求一遍前缀和

第二种写法:a\[\]原数组;b\[\]差分标记数组,标记a\[\]的改变量;sum\[\]:b\[\]的前缀和数组(a\[\]的总改变量数组)

二维差分

二位差分数组:

对二位前缀和的逆运算

二位差分数组的区间修改

bxy++

bx+1y--

bxy+1--

bx+1y+1++

二维差分例题

重点

区间增值时,二位差分是如何改变的

相关推荐
JieE2121 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言