前缀和算法 算法4

算法题中帮助复习的知识

vector<int > dp( n ,k); n为数组大小 ,k为初始化

哈希表unordered_map<int ,int > hash;

hash.find(k)返回值是迭代器 ,找到k返回其迭代器 没找到返回hash.end()

hash.count(k)返回值是数字 ,找到k返回1 ,没找到返回0.

C++和java中

负数%正数 = 负数

处理手段

(a%k+k)%k 能使不管正负数%正数都为正数

前缀和算法是一种常用的预处理技术,用于高效地计算数组或序列中某个区间的和

通过预先计算并存储前缀和,可以在常数时间内查询任意区间的和,从而显著提高查询效率

注意:

不一定使用数组存储

hash(unordered_map)可以迅速找到一个数的次数 ,用hash.find()! =hash.end()

或者hash.count != 0
不一定存储的是前缀和 ,也可能是前缀和的余数974. 和可被 K 整除的子数组 - 力扣(LeetCode)

这里要灵活变通.

相关推荐
BFT白芙堂几秒前
Franka 机器人x Dexterity Gen引领遥操作精细任务新时代
人工智能·算法·机器学习·具身智能·franka机器人·科研机器人·机器人解决方案
LuckyLay8 分钟前
LeetCode算法题(Go语言实现)_38
算法·leetcode·golang
Chiyamin27 分钟前
图算法基础
数据结构·c++·算法
C——Coder30 分钟前
关于柔性数组
算法·柔性数组
AlgoNewbie35 分钟前
牛客周赛 Round 88【题解完成】
算法
luckycoding1 小时前
2747. 统计没有收到请求的服务器数目
算法
TT哇2 小时前
【前缀和】矩阵区域和(medium)
java·线性代数·算法·矩阵
Elendill4 小时前
【算法笔记】并查集详解
笔记·python·算法
BanyeBirth4 小时前
C++高精度算法(加、减、乘)
开发语言·c++·算法
houliabc4 小时前
C语言个人笔记
c语言·数据结构·笔记·算法