【算法基础】一维前缀和 + 二维前缀和

article/2025/10/1 21:09:09

在这里插入图片描述

👦个人主页:Weraphael
✍🏻作者简介:目前正在学习c++和算法
✈️专栏:【C/C++】算法
🐋 希望大家多多支持,咱一起进步!😁
如果文章有啥瑕疵
希望大佬指点一二
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注😍


目录

  • 一、一维前缀和
      • 1.1 什么是一维前缀和
      • 1.2 如何求Sn
      • 1.3 用途
      • 1.4 代码模板
      • 1.5 细节问题
  • 二、二维前缀和
      • 2.1 用途
      • 2.2 前缀和S[i][j]求法
      • 2.3 子矩阵求法
      • 2.4 代码模板
  • 三、总结

一、一维前缀和

1.1 什么是一维前缀和

前缀和就是新建一个数组,数组中保存的是原数组前n项的和

【举个例子】

  • Sn = a1+a2+a3+…an, Sn就是数列的前缀和(下标一定要从1开始,后面会讲解原因)

在这里插入图片描述

1.2 如何求Sn

我们可以利用上面的图来找找规律

在这里插入图片描述

  • S1 = a1
  • S2 = a1 + a2 = S1 + a2
  • S3 = a1 + a2 + a3 = S2 + a3
  • S4 = a1 + a2 + a3 + a4 = S3 + a4
  • S5 = a1 + a2 + a3 + a4 + a5 = S4 + a5
  • 这一套下来,前缀和的公式很明显就是:Si = Si-1 + ai

【代码】

for (int i = 1;i <= n;i++)
{s[i] = s[i-1] + a[i];
}

1.3 用途

能快速求出数列中某一段的和,时间复杂度为O(1)

还是要利用这幅图

在这里插入图片描述
假设我们要计算原数组a中区间[2,4]的和,我们就可以用S4 - S1

在这里插入图片描述

  • 总结:假设日后题目要求区间[l,r]的和,其实也能循环遍历,不过时间复杂度是O(N),而前缀和的时间复杂度是O(1)
  • 计算区间[l,r]的和,其公式为Sr - Sl-1

1.4 代码模板

#include <iostream>
using namespace std;const int N = 100010;
int a[N],s[n];int main()
{int n; //n - 原数组元素的个数scanf("%d",&n);//输入原数组for (int i = 1;i <= n;i++) {scanf("%d",&a[i]);}//前缀和公式for (int i = 1;i <= n;i++){s[i] = s[i - 1] + a[i];}//以下是计算某段区间的和int l,r;scanf("%d%d",&l,&r);printf("%d\n",s[r] - s[l - 1]);return 0;
}

1.5 细节问题

  • 首先,下标从1开始就是为了定义S0,就拿前缀和公式来说,S[i] = S[i-1] + a[i],当i = 1时,出现了S0,而S0要及时置为0,原因是为了统一。举个例子,假设要计算区间[1,10]之间的和,明眼就能看出是要计算S10,而为了达到统一计算的效果,S10 - S0 = S10 - 0.
  • 为什么我在代码中没有定义S[0]=0,原因是我将s[N]定成了全局变量,而全局变量有一个特点:默认初始化为0!

二、二维前缀和

2.1 用途

目的是求出一个矩阵中某一个小矩阵的和

2.2 前缀和S[i][j]求法

大家画图可能会更加容易理解点,假设点(i,j)在矩阵的正中心,S[i][j] 即为黄色部分所有数的的和

在这里插入图片描述

我们可以分三步求出黄色部分的和

  • 第一步先求出红色部分所有数的和

在这里插入图片描述

列出式子:S[i][j] = S[i][j-1] + ...

  • 第二步再求出绿色部分所有数的和

在这里插入图片描述

列出式子:S[i][j] = S[i][j-1] + S[i-1][j] + ...

  • 第三步去重,因为前两部重复加上了黑色部分所有数的和,因此要减掉一次

在这里插入图片描述

最后别忘了加上了本身:a[i][j]
列出式子:S[i][j] = S[i][j-1] + S[i-1][j] - S[i-1][j-1] + a[i][j]

2.3 子矩阵求法

假设要求左上角为(x1,y1),右下角为(x2,y2)所围成黄色部分所有数的和

在这里插入图片描述

子矩阵的求法和求S[i][j]是类似的,四步走

  • 第一步,先求出红色部分围成所有数的和

在这里插入图片描述

列出式子:S = S[x2][y2] - ...

  • 第二步,在用上一步红色部分减去绿色部分所有数的和

在这里插入图片描述

列出式子:S = S[x2][y2] - S[x1 - 1][y2] - ...

  • 第三步,再减去灰色部分所有数的和

在这里插入图片描述

列出式子:S = S[x2][y2] - S[x1 - 1][y2] - S[x2][y1 - 1] + ...

  • 第四步去重,因为前两部重复减去了紫色部分所有数的和,因此要加上一次

在这里插入图片描述

列出式子:S = S[x2][y2] - S[x1 - 1][y2] - S[x2][y1 - 1] + S[x1 - 1][y1 - 1]

2.4 代码模板

#include <iostream>
using namespace std;const int N = 10010;
int n, m;
int a[N][N],s[N][N];int main()
{scanf("%d%d%d", &n, &m); //n -行 m - 列//输入数组for (int i = 1; i <= n; i ++ )for (int j = 1; j <= m; j ++ )scanf("%d", &a[i][j]);//二维前缀和公式for (int i = 1; i <= n; i ++ )for (int j = 1; j <= m; j ++ )s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + a[i][j];//求子矩阵int x1, y1, x2, y2;scanf("%d%d%d%d", &x1, &y1, &x2, &y2);printf("%d\n", s[x2][y2] - s[x1 - 1][y2] - s[x2][y1 - 1] + s[x1 - 1][y1 - 1]);return 0;
}

三、总结

其实大家只要背下前缀和公式就好了

  • 一维前缀和公式:S[i]= S[i-1] + a[i]
  • 求某段区间[l,r]: S[r]- S[l-1]

  • 二维前缀和公式:S[i][j] = S[i][j-1] + S[i-1][j] - S[i-1][j-1] + a[i][j]
  • 求子矩阵公式:S = S[x2][y2] - S[x1 - 1][y2] - S[x2][y1 - 1] + S[x1 - 1][y1 - 1]

http://chatgpt.dhexx.cn/article/CvLecYoD.shtml

相关文章

前缀和与差分总结

目录 1.前缀和 2.前缀和算法的好处 3.二维前缀和 4.差分 5.一维差分 6.二维差分 1.前缀和 前缀和是指某序列的前n项和&#xff0c;可以把它理解为数学上的数列的前n项和&#xff0c;而差分可以看成前缀和的逆运算。合理的使用前缀和与差分&#xff0c;可以将某些复杂的…

一维前缀和

今天我们来讲讲一维前缀和 首先我们来介绍一下一维前缀和&#xff0c;emmm其实和数列的前n项和差不多&#xff0c;它能在 O ( 1 ) O(1) O(1) 的时间复杂度操作数组的任意子区间&#xff0c;比如我们要找出一段区间的和。 我们先预处理出一个前缀和数组&#xff0c;为了方便使…

【算法】前缀和(一维前缀和与二维前缀和)

前缀和是一种重要的预处理&#xff0c;能大大降低查询的时间复杂度。 【一维前缀和】 给定一个数组A[1,2,……n]&#xff0c;则它的前缀和数组为PrefixSum[1..n]。定义为&#xff1a;PrefixSum[i] A[0]A[1]...A[i-1]&#xff1b; 【例子】 A[5,6,7,8] --> PrefixSum[5,…

【Python 百练成钢】前缀和

文章目录 前言&#x1f607;一维前缀和&#x1f608;问题描述问题分析代码实现 二维前缀和&#x1f47f;问题描述问题分析代码实现 ฅʕ•̫͡•ʔฅ&#x1f4af; 前言&#x1f607; 今天分享一下学到的基础算法前缀和。 首先了解一下前缀和的基础概念&#x1f604; 有一个序列…

【每日一算法】二维前缀和算法 _ 模板应用

&#x1f49b; 前情提要&#x1f49b; 本章节是每日一算法的二维前缀和算法的相关知识~ 接下来我们即将进入一个全新的空间&#xff0c;对代码有一个全新的视角~ 以下的内容一定会让你对数据结构与算法有一个颠覆性的认识哦&#xff01;&#xff01;&#xff01; ❗以下内容…

基础算法:二维前缀和

二维前缀和C模板&#xff1a; S[i, j] 第i行j列格子左上部分所有元素的和 S[i, j] S[i-1,j] s[i,j-1] - S[i-1,j-1] a[i,j](表示当前的数) 以(x1, y1)为左上角&#xff0c;(x2, y2)为右下角的子矩阵的和为&#xff1a; S[x2, y2] - S[x1-1,y2] - S[x2,y1-1] S[x1-1,y1-1]…

二维前缀和

二维前缀和 直接看一个例子 假设给定一个矩阵 1 2 4 3 5 1 2 4 6 3 5 9 那么&#xff0c;可以推出他的二维前缀和矩阵为 1 3 7 10 6 9 15 22 12 18 29 45 在二维前缀和数组中&#xff0c;9 1 2 5 1 15 1 2 5 1 4 2 18 1 5 6 2 1 3… … 即二位前缀和数组中第 …

二维数组前缀和

二维数组前缀和 对于二维数组求前缀和,我们先预处理第一行跟第一列的前缀和 第一行跟第一列的前缀和可以看作一维数组的前缀和 前缀和数组的0,0等于原数组的0,0,第一行为原数组第一行的前缀和,第一列为第一列的前缀和 预处理: //原数组 int arr[110][110]{{},{0,1,2,3,4,5,…

前缀和与经典例题详解

前缀和与及经典例题详解 南昌理工ACM集训队 这是目录 前缀和与及经典例题详解前言前缀和P5638 光骓者的荣耀 二维前缀和P2004 领地选择 最大子段和P1115 最大子段和P1719 最大加权矩形 写在最后 前言 下面的例题都出自于洛谷官方算法2-1题单&#xff0c;有兴趣的同学可以去水…

前缀和(C/C++)

目录 1. 前缀和的定义 2. 一维前缀和 2.1 计算公式 2.2 用途 2.3 小试牛刀 3. 二维前缀和 3.1 用途 1. 前缀和的定义 对于一个给定的数列A&#xff0c;他的前缀和数中 S 中 S[ i ] 表示从第一个元素到第 i 个元素的总和。 如下图&#xff1a;绿色区域的和就是前缀和数组…

前缀和(C++)实现

每日一句&#xff1a;真正让人变好的选择过程都不会很舒服&#xff0c;所以人们明知道什么都不做&#xff0c;会比较轻松&#xff0c;但依旧选择追逐梦想。 前缀和 前言一、一维前缀和1.前缀和是什么&#xff1f;2.暴力做法3.前缀和求区间大小3.1如何构成前缀和的形式&#xff…

差分与前缀和

目录 前言 一、算法原理 二、算法图解 三、算法模板 四、算法应用 前言 天梯赛和省赛快开始了&#xff0c;不想拖后腿&#xff0c;边更边学习吧。 酝酿好久的第一篇博客&#xff0c;缺点不少&#xff0c;多多指教吖。 点赞鼓励一下吧&#xff0c;亲。&#x1f619;&#x1…

算法设计 - 前缀和 差分数列

一维数组前缀和的概念 前缀和的概念很简单&#xff0c;我们用一维数组的前缀和来举例&#xff0c;有如下一维数组&#xff1a; arr [1, 2, 3, 4, 5] 该数组的前缀和数组如下 preSum [1, 3, 6, 10, 15] 关系如下&#xff1a; preSum[0] arr[0]preSum[1] arr[0] arr[1]pre…

python 前缀和总结

前缀和是数据结构与算法中比较重要的知识&#xff0c;前缀和经常可以结合哈希表解决很多有意思的问题。为了方便学习&#xff0c;在这里总结leetcode中出现的前缀和问题。 525. 连续数组 给定一个二进制数组 nums &#xff08;只含有0&#xff0c;1&#xff09;, 找到含有相同…

【c++入门(2)】前缀和

大纲 1.计算前缀和 2.计算字段和 3.后缀和 4.前缀积 5.后缀积 6.例题 1.计算前缀和 基础问题&#xff1a; 思路1&#xff1a; 枚举 cin (); for (int i 1; i < q; i) {cin >> x;int sum 0;for (int j 1; j < x; j){sum a[j];}cout << sum << endl…

前缀和

【前缀和】 什么是前缀和&#xff1f;前缀和是一个数组的某项下标之前(包括此项元素)的所有数组元素的和。 设b[]为前缀和数组&#xff0c;a[]为原数组&#xff0c;根据这句话可以得到前缀和的定义式和递推式&#xff1a; 定义式递推式一维前缀和 二维前缀和 【一维前缀和】…

Java前缀和算法

一.什么是前缀和算法 通俗来讲&#xff0c;前缀和算法就是使用一个新数组来储存原数组中前n-1个元素的和&#xff08;如果新数组的当前元素的下标为n&#xff0c;计算当前元素的值为原数组中从0到n-1下标数组元素的和&#xff09;&#xff0c;可能这样讲起来有点抽象&#xff0…

基础算法——前缀和详解

秋名山码民的主页 &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f64f;作者水平很有限&#xff0c;如果发现错误&#xff0c;一定要及时告知作者 前言 由于有些读者朋友私聊我&#xff0c;希望出几期基础算法的讲解&#xff0c;kmp&…

前缀和算法

文章目录 前言一、关于前缀和二、一维数组求前缀和1.求段区间前缀和2.例题&#xff1a;AcWing795. 前缀和AC代码 三、二维数组求前缀和1.求S[i,j]2.求&#xff08;x1&#xff0c;y1&#xff09;&#xff0c;&#xff08;x2&#xff0c;y2&#xff09;子矩阵的和3.例题&#xff…

前缀和详解

目录 前缀和概念前缀和代码前缀和例题题目介绍思路分析相关代码 总结 前缀和概念 前缀和&#xff1a;顾名思义&#xff0c;是要求前缀的总和&#xff0c;什么是前缀&#xff0c;对于一个存放数字的数组而言&#xff0c;前缀就是指的数组的前k项&#xff0c;因此对应的前缀和就…