【算法笔记】前缀和算法原理深度剖析(超全详细版)

【算法笔记】前缀和算法原理深度剖析(超全详细版)

🔥个人主页:大白的编程日记
🔥专栏:算法笔记

文章目录
- 【算法笔记】前缀和算法原理深度剖析(超全详细版)
- 前言
- 一.一维前缀和
- 1.1题目
- 1.2算法原理解析
- 1.3代码实现
- 二.二维前缀和
- 2.1题目
- 2.2算法原理解析
- 2.3下标映射
- 2.4初始化问题
- 2.5代码实现
- 三.寻找数组的中心下标
- 3.1题目
- 3.2思路分析
- 3.3代码实现
- 四.除自身以外数组的乘积
- 4.1题目
- 4.2思路分析
- 4.3总结
- 4.4代码实现
- 五.和为k的子数组
- 5.1题目
- 5.2思路分析
- 5.3代码实现
- 六.和可被k整除的子数组
- 6.1题目
- 6.4思路分析
- 6.3代码实现
- 七.连续数组
- 7.1题目
- 7.1思路分析
- 7.3代码实现
- 八.矩阵区域和
- 8.1题目
- 8.2思路分析
- 8.3代码实现
- 后言
前言
哈喽,各位小伙伴大家好!上期我们讲了二分算法。今天我们来讲前缀和的算法原理。话不多说,咱们进入正题!向大厂冲锋!
一.一维前缀和
1.1题目
- 题目:【模板】前缀和

1.2算法原理解析
我们根据前缀和算法就可以快速求出区间和。

为了防止越界,我们要让前缀和数组下标从1开始。
1.3代码实现
#include <iostream>
#include<vector>
using namespace std;
int main()
{int n,q;cin>>n>>q;vector<long long> dp(n+1);//多开一个节点防止越界int tmp=0;for(int i=1;i<=n;i++){cin>>dp[i];}for(int i=1;i<=n;i++){dp[i]+=dp[i-1];}int l,r;while(q--){cin>>l>>r;cout<<dp[r]-dp[l-1]<<endl;}
}
// 64 位输出请用 printf("%lld")

二.二维前缀和
2.1题目
- 题目:二维前缀和

2.2算法原理解析

2.3下标映射

2.4初始化问题
如果用到两个前缀和区间求某区间的和
我们初始化的值并不重要。

- 验证


2.5代码实现
#include <iostream>
#include<vector>
using namespace std;int main()
{int n, m, q;cin >> n >> m >> q;vector<vector<long long>> arr(n,vector<long long>(m));for (int i = 0; i <n; i++){for (int j = 0; j < m; j++){cin >> arr[i][j];}}vector<vector<long long>> dp(n+1,vector<long long>(m + 1));for (int i = 1; i <=n; i++){for (int j = 1; j <= m; j++){dp[i][j] = dp[i][j - 1]+dp[i-1][j]-dp[i-1][j-1]+arr[i-1][j-1];}}while (q--){int x1, y1, x2, y2;cin >> x1 >> y1 >> x2 >> y2;long long sum=0;sum=dp[x2][y2]-dp[x2][y1-1]-dp[x1-1][y2]+dp[x1-1][y1-1];cout<<sum<<endl;}
}

三.寻找数组的中心下标
3.1题目
- 题目:寻找数组的中心下标

3.2思路分析
这里我们借助前缀和数组和后缀和数组即可快速判断中心下标。

3.3代码实现
class Solution {
public:int pivotIndex(vector<int>& nums){int n=nums.size();vector<int> f(n),g(n);for(int i=1;i<n;i++)//前缀和数组{f[i]=nums[i-1]+f[i-1];}for(int i=n-2;i>=0;i--)//后缀和数组{g[i]=g[i+1]+nums[i+1];}for(int i=0;i<n;i++)//判断{if(f[i]==g[i]){return i;}}return -1;}
};

四.除自身以外数组的乘积
4.1题目
- 题目:除自身以外数组的乘积

4.2思路分析

4.3总结

4.4代码实现
class Solution {
public:vector<int> productExceptSelf(vector<int>& nums) {int n=nums.size();vector<int> f(n),g(n),ret(n);f[0]=g[n-1]=1;for(int i=1;i<n;i++)//前缀和数组{f[i]=f[i-1]*nums[i-1];}for(int i=n-2;i>=0;i--)//后缀和数组{g[i]=g[i+1]*nums[i+1];}for(int i=0;i<n;i++){ret[i]=f[i]*g[i];}return ret;}
};

五.和为k的子数组
5.1题目
- 题目:和为k的子数组

5.2思路分析

5.3代码实现
class Solution {
public:int subarraySum(vector<int>& nums, int k) {unordered_map<int,int> hash;hash[0]=1;//整个区间和为kint sum=0,ret=0;for(auto e:nums){sum+=e;//计算前缀和if(hash.count(sum-k))//统计和为sum-k区间个数{ret+=hash[sum-k];}hash[sum]++;//填入前缀和信息}return ret;}
};

六.和可被k整除的子数组
6.1题目
- 题目:和可被k整除的子数组

6.4思路分析

6.3代码实现
class Solution {
public:int subarraysDivByK(vector<int>& nums, int k) {unordered_map<int,int> hash;hash[0]=1;//整个区间和为kint sum=0,ret=0;for(auto e:nums){sum+=e;//计算前缀和if(hash.count((sum%k+k)%k))//统计和为被k整除区间个数负数修正{ret+=hash[(sum%k+k)%k];}hash[(sum%k+k)%k]++;//填入前缀和%k信息}//(a-b)%p==a%p==b%p同余定理return ret;}
};

七.连续数组
7.1题目
- 题目:连续数组

7.1思路分析

7.3代码实现
class Solution {
public:int findMaxLength(vector<int>& nums){unordered_map<int,int> hash;hash[0]=-1;int sum=0,len=0;for(int i=0;i<nums.size();i++){sum+=(nums[i]==0?-1:1);//0就变成-1;if(hash.count(sum-0)){len=max(len,i-hash[sum]);//更新长度}else//相同的前缀和不更新{hash[sum]=i;//更新哈希表前缀和信息}}return len;}
};

八.矩阵区域和
8.1题目
- 题目:矩阵区域和

8.2思路分析

8.3代码实现
class Solution {
public:vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k){int m=mat.size(),n=mat[0].size();vector<vector<int>> arr(m+1,vector<int>(n+1));for(int i=1;i<m+1;i++)//处理前缀和数组{for(int j=1;j<n+1;j++){arr[i][j]=arr[i][j-1]+arr[i-1][j]-arr[i-1][j-1]+mat[i-1][j-1];}}vector<vector<int>> arr1(m,vector<int>(n));for(int i=0;i<m;i++){for(int j=0;j<n;j++){int x1=max(0,i-k)+1;int x2=min(m-1,i+k)+1;int y1=max(0,j-k)+1;int y2=min(n-1,j+k)+1;//计算下标 +1映射dp数组arr1[i][j]=arr[x2][y2]-arr[x2][y1-1]-arr[x1-1][y2]+arr[x1-1][y1-1];}}return arr1;}
};

后言
这就是前缀和算法原理的深度剖析。大家自己好好消化理解。今天 就分享到这,感谢各位大耐心垂阅!咱们下期见!拜拜~

相关文章:
【算法笔记】前缀和算法原理深度剖析(超全详细版)
【算法笔记】前缀和算法原理深度剖析(超全详细版) 🔥个人主页:大白的编程日记 🔥专栏:算法笔记 文章目录 【算法笔记】前缀和算法原理深度剖析(超全详细版)前言一.一维前缀和1.1题…...
linux之网络子系统- 地址解析协议arp 源码分析和邻居通用框架
一、arp 的作用 ARP(Address Resolution Protocol,地址解析协议)是将IP地址解析为以太网MAC地址(物理地址)的协议。在局域网中,当主机或其他网络设备有数据要发送给另一个主机或设备时,它必须知…...
经典动态规划问题:含手续费的股票买卖【从 O(n) 到 O(1) 的优化解析】
题目理解 我们要在给定的股票价格数组 prices 中进行买卖操作,并尽可能多次交易以获取最大利润。每次交易都需要支付一定的手续费 fee,因此我们必须考虑如何通过合适的交易策略最大化利润。 在本题中,每一天可以选择: 不进行任…...
Python画笔案例-088 绘制 滚动的汉字
1、绘制 滚动的汉字 通过 python 的turtle 库绘制 滚动的汉字,如下图: 2、实现代码 绘制 滚动的汉字,以下为实现代码: """滚动的汉字.py """ import time from turtle import * from write_patch import *width,height...
Redis 5.0 安装配置(Windows)
Redis 5.0之后支持Redis Stream等功能 下载地址:Releases tporadowski/redis GitHub 点击运行redis-server.exe 此外:Redis 6.0及以后版本目前都没有Windows版...
金融行业:办公安全防护专属攻略
在中国金融市场快速迈向数字化转型的进程中,数据安全与隐私保护成为了不容忽视的关键议题。面对不断升级的网络威胁和日益严格的监管要求,构建一个既能支持创新又能提供坚实防护的信息安全体系变得尤为重要。亿格云不断深耕办公安全领域,为金…...
python如何基于numpy pandas完成复杂的数据分析操作?
数据分析是现代数据科学的重要组成部分,Python作为一种强大的编程语言,提供了许多库来简化数据分析过程。 其中,NumPy和Pandas是两个最常用的库。NumPy主要用于数值计算,而Pandas则提供了强大的数据结构和数据分析工具。 本文将深入探讨如何利用这两个库进行复杂的数据分…...
Linux中定时任务调度工具——crontab
1.简介 crontab是Unix和类Unix操作系统(如Linux)中用于定时任务调度的工具。其名称来源于“cron”这个守护进程,它负责周期性地执行任务,并且“tab”表示这个工具的配置文件。用户可以通过配置crontab文件来设定定时任务…...
思维+差分,CF 1884C - Medium Design
目录 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 1884C - Medium Design 二、解题报告 1、思路分析 考虑 最大值 和 最小值…...
简单介绍冯诺依曼体系
现代的计算机, 大多遵守冯诺依曼体系结构 CPU中央处理器:进行算术运算和逻辑判断。存储器:分为外存和内存,用于存储数据(使用二进制方式存储)。输入设备:用户给计算机发号施令。输出设备:计算机…...
kernel32.dll下载地址:如何安全地恢复系统文件
关于从网络上寻找kernel32.dll的下载地址,这通常不是一个安全的做法,而且可能涉及到多种风险。kernel32.dll是Windows操作系统的核心组件之一,负责内存管理、进程和线程管理以及其他关键系统功能。因为kernel32.dll是系统的基础文件ÿ…...
【高等数学】多元微分学 (一)
偏导数 偏导数定义 如果二元函数 f f f 在 x 0 , y 0 x_0,y_0 x0,y0 的某邻域有定义, 且下述极限存在 lim Δ x → 0 f ( x 0 Δ x , y 0 ) − f ( x 0 , y 0 ) Δ x \lim_{\Delta x\to 0} \frac{f(x_0\Delta x,y_0)-f(x_0,y_0)}{\Delta x} Δx→0limΔxf(x0Δ…...
Python爬取京东商品信息,详细讲解,手把手教学(附源码)
Python 爬虫爬取京东商品信息 下面我将逐一解释每一部分的代码 导入库 from selenium import webdriver from selenium.webdriver.edge.service import Service from selenium.webdriver.edge.options import Options import time import random import csv from selenium.c…...
大家有没有了解过TLKS-PLGS这款接地电阻在线监测装置?它在电力系统中能发挥什么作用呢?
接地电阻在线监测仪(输电铁塔接地电阻监测装置、变电站接地电阻监测装置、三极法接地网电阻监测装置)在电力系统中发挥着至关重要的作用,具体来说,有以下几个方面: 一、实时监测预警。该装置采用激励脉冲技术…...
Shell中的函数
目录 一、系统函数 (一)前言 (二)常用的函数 basename [string/pathname] [suffix] 二、自定义函数 (一)语法 (二)脚本例子 三、函数实际案例 过程中的报错: …...
通过IP地址或者主机名添加打印机20241023
文印室打印机连接方式20241023 Win键盘搜索打印机和扫描仪点击添加打印机或扫描仪,等候片刻点击“我需要的打印机不在列表中”添加打印机,选择使用IP地址或主机名添加打印机点击下一步,设备类型选择自动检测输入主机名:即打印机有…...
基于SpringBoot+Vue智慧养老关爱系统【提供源码+答辩PPT+参考文档+项目部署】
💥 这两年毕业设计和毕业答辩的要求和难度不断提升,传统的JavaWeb项目缺少创新和亮点,往往达不到毕业答辩的要求! ❗如何解决这类问题? 让我们能够顺利通过毕业,我也一直在不断思考、努力、精进。通过2024年…...
新手教学系列——利用短效代理快速搭建代理池
引言 在进行高并发数据抓取时,很多人都会遇到频繁IP被封的问题。要解决这个问题,代理池的搭建就成了关键。通过频繁更换代理IP,我们可以绕过网站的反爬机制,提升抓取效率。然而,很多初学者可能会觉得构建一个健壮的代理池颇为复杂,尤其是需要快速切换的短效代理池。在这…...
实体与DTO如何转换
下面是一些常用的转换库: Dozer 该项目目前不活跃,并且很可能在未来被弃用。 ModelMapper 一个智能对象映射库,可自动将对象相互映射。它采用基于约定的方法,同时提供简单、重构安全的应用程序接口(API)来…...
Docker 安装Postgres和PostGIS,并制作镜像
1. 查找postgres和postgis现有的镜像和版本号 镜像搜索网站:https://docker.aityp.com/ 测试使用的是postgres:15.4 和 postgis:15-3.4 2、镜像拉取 docker pull postgres:15.4docker pull postgis/postgis:15-3.4镜像下载完成,docker images 查看如…...
阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...
[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?
论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...
3-11单元格区域边界定位(End属性)学习笔记
返回一个Range 对象,只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意:它移动的位置必须是相连的有内容的单元格…...
docker 部署发现spring.profiles.active 问题
报错: org.springframework.boot.context.config.InvalidConfigDataPropertyException: Property spring.profiles.active imported from location class path resource [application-test.yml] is invalid in a profile specific resource [origin: class path re…...
【Go语言基础【12】】指针:声明、取地址、解引用
文章目录 零、概述:指针 vs. 引用(类比其他语言)一、指针基础概念二、指针声明与初始化三、指针操作符1. &:取地址(拿到内存地址)2. *:解引用(拿到值) 四、空指针&am…...
AirSim/Cosys-AirSim 游戏开发(四)外部固定位置监控相机
这个博客介绍了如何通过 settings.json 文件添加一个无人机外的 固定位置监控相机,因为在使用过程中发现 Airsim 对外部监控相机的描述模糊,而 Cosys-Airsim 在官方文档中没有提供外部监控相机设置,最后在源码示例中找到了,所以感…...
搭建DNS域名解析服务器(正向解析资源文件)
正向解析资源文件 1)准备工作 服务端及客户端都关闭安全软件 [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 2)服务端安装软件:bind 1.配置yum源 [rootlocalhost ~]# cat /etc/yum.repos.d/base.repo [Base…...

