【Python 百练成钢】前缀和

article/2025/10/1 21:18:32

文章目录

  • 前言😇
  • 一维前缀和😈
    • 问题描述
    • 问题分析
    • 代码实现
  • 二维前缀和👿
    • 问题描述
    • 问题分析
    • 代码实现
  • ฅʕ•̫͡•ʔฅ💯

前言😇

今天分享一下学到的基础算法前缀和。
首先了解一下前缀和的基础概念😄
有一个序列,序列内包含很多数a1、a2、a3、a4、a5、a6、a7
a1的前缀和就是a1
a2的前缀和就是a1+a2
a3的前缀和就是a1+a2+a3

此时可以定义一个序列bn专门用于存放关于an的前缀和
b1、b2、b3、b4、b5、b6、b7
使得:

b1=a1
b2=a1+a2
b3=a1+a2+a3

这样就得到了一个关于a序列的前缀和序列,在进行一些运算的时候可以大大的降低时间复杂度。
写题的时候步骤就是

  • (1)确定前缀和序列
  • (2)使用位置关系对前缀和序列进行查询,得到想要的结果

具体如何用听我细细道来
在这里插入图片描述

一维前缀和😈


问题描述

输入一个长度为n的整数序列。
接下来再输入m个询问,每个询问输入一对l, r。
对于每个询问,输出原序列中从第l个数到第r个数的和。
输入格式
第一行包含两个整数n和m。
第二行包含n个整数,表示整数数列。
接下来m行,每行包含两个整数l和r,表示一个询问的区间范围。
输出格式
共m行,每行输出一个询问的结果。
数据范围
1≤l≤r≤n,
1≤n,m≤100000,
−1000≤数列中元素的值≤1000
输入样例:
5 3
2 1 3 6 4
1 2
1 3
2 4
输出样例:
3
6
10

问题分析

对于一维前缀和直接构造前缀和序列即可,然后打印l与r位置的前缀和元素之差。
可以将所有的结果先添加到一个序列中,在输入所有操作之后一块打印。

代码实现

老规矩先上运行结果:
在这里插入图片描述

# 暴力解决'''
import sys
n,m=sys.stdin.readline().strip().split()
n,m=int(n),int(m)
nls=[]
ans=[]
ls=[int(x) for x in sys.stdin.readline().strip().split()]for i in range(m):l,r=sys.stdin.readline().strip().split()l,r=int(l),int(r)sum=0for i in range(l-1,r):sum+=ls[i]ans.append(sum)
print(ans)
'''# 前缀和
'''
先将数据处理一下,然后在进行计算的时候就是进行查询
显然进行查询要方便的多。
'''
import sys
n,m=sys.stdin.readline().strip().split()
n,m=int(n),int(m)
ls=[int(x) for x in sys.stdin.readline().strip().split()]
als=[]
ans=[]
als.append(0)
ans.append(0)
# print(ls,als,ans)
als.append(ls[0])
for j in range(1,n):als.append(als[len(als)-1]+ls[j])
for i in range(m):l,r=sys.stdin.readline().strip().split()r,l=int(r),int(l)ans.append(als[r]-als[l-1])
# print(ans)
for i in range(1,m+1):print(ans[i])

二维前缀和👿


问题描述

输入一个n行m列的整数矩阵,再输入q个询问,每个询问包含四个整数x1, y1, x2, y2,表示一个子矩阵的左上角坐标和右下角坐标。
对于每个询问输出子矩阵中所有数的和。
输入格式
第一行包含三个整数n,m,q。
接下来n行,每行包含m个整数,表示整数矩阵。
接下来q行,每行包含四个整数x1, y1, x2, y2,表示一组询问。
输出格式
共q行,每行输出一个询问的结果。
数据范围
1≤n,m≤1000,
1≤q≤200000,
1≤x1≤x2≤n,
1≤y1≤y2≤m,
−1000≤矩阵内元素的值≤1000
输入样例:
3 4 3
1 7 2 4
3 6 2 8
2 1 2 3
1 1 2 2
2 1 3 4
1 3 3 4
输出样例:
17
27
21

问题分析

应准备一个矩阵,一个用于存放以(1,1)与(x1,y1)矩阵中的元素和
在进行求取面积内元素和的时候,使用矩阵元素之间的关系。
此时面临两个问题(可以配合图片进行理解):
对于以下图片中均是左边代表原始矩阵,右边代表和矩阵

一、矩阵求求和
对应颜色矩阵的框所有数的和求出来后放进对应颜色的位置
由于矩阵叠加,所以我们在进行求和的时候应先加然后再减去叠加的部分故可得:
b33=a33+b32+b23-b22在这里插入图片描述
二、矩阵求差(这也是最终面临的问题)
由于矩阵叠加,所以我们在进行求差的时候应先减去矩阵周围的矩阵和,然后加上重复减去的部分:
故可得下标为a22与a33围成的矩阵所有元素和为:b22-33=b33-b31+b13+b11
这里进行求解的时候可能面临坐标交换,a22-a33围成的矩阵,与a32-a23围成的是一个矩阵
所以我们不妨将ax1y1中的下标均换成最小的便于计算。(也就是说转换成x1<x2,y1<y2)
然后以最小的坐标与最大的坐标为界,减去所求矩阵周围的矩阵
在这里插入图片描述

代码实现

老规矩先上运行结果:
在这里插入图片描述

import sysans=[]
# 原始矩阵
amatrix=[]# 前缀和矩阵
bmatrix=[]# 读入n,m,q并将其转换为数值类型
n,m,q=sys.stdin.readline().strip().split()
n,m,q=int(n),int(m),int(q)# 初始化前缀和矩阵
for i in range(n+1):bmatrix.append([0]*(m+1))# 读入原始矩阵
for i in range(n):amatrix.append([int(x) for x in sys.stdin.readline().strip().split()])#利用原始矩阵,求前缀和矩阵
i=1
# 行
while i<=n:j=1# 列while j<=m:bmatrix[i][j]=amatrix[i-1][j-1]+bmatrix[i][j-1]+bmatrix[i-1][j]-bmatrix[i-1][j-1]j+=1i+=1# 测试是否创建前缀和矩阵成功
# for i in bmatrix:
#     print(i)# 写入坐标矩阵
qm=[]
for i in range(q):qm.append([int(x) for x in sys.stdin.readline().strip().split()])# 计算某段矩阵的和
i=0
while i<q:# 处理矩阵中的xy,确保x2y2在矩阵的右下方便于后面计算if qm[i][0]>qm[i][2]:qm[i][0],qm[i][2]=qm[i][2],qm[i][0]if qm[i][1]>qm[i][3]:qm[i][1],qm[i][3]=qm[i][3],qm[i][1]ans.append(bmatrix[qm[i][2]][qm[i][3]]-bmatrix[qm[i][0]-1][qm[i][3]]-bmatrix[qm[i][2]][qm[i][1]-1]+bmatrix[qm[i][0]-1][qm[i][1]-1])# print(qm[i])i+=1
# 结果输出
print(ans)

ฅʕ•̫͡•ʔฅ💯

ᴴᴬᵛᴱ ᴬ ᴳᴼᴼᴰ ᵀᴵᴹᴱ


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

相关文章

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

&#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;因此对应的前缀和就…

前缀和与差分 图文并茂 超详细整理(全网最通俗易懂)

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

算法:解数独

题目内容 编写一个程序&#xff0c;通过已填充的空格来解决数独问题。 一个数独的解法遵循如下规则&#xff1a; 数字 1-9 在每一行只能出现一次。数字 1-9 在每一列只能出现一次。数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。 本题满足以下设定&#xff1a; …

算法_回溯_解数独

文章目录 解数独1.解法2.总结python算法 解数独 leetcode链接 1.解法 这道题是一个棋盘问题&#xff0c;而棋盘问题是一个典型的回溯问题。 首先思考普通人&#xff08;这里指没有受过专业训练的人&#xff09;解数独的方法&#xff0c;那就是首先在空白位置假设一个数字&a…

Java编程实战12:解数独

目录 解数独题目示例 1提示 解答解题思路完整代码 解数独 题目 编写一个程序&#xff0c;通过填充空格来解决数独问题。 数独的解法需 遵循如下规则&#xff1a; 数字 1-9 在每一行只能出现一次。数字 1-9 在每一列只能出现一次。数字 1-9 在每一个以粗实线分隔的 3x3 宫内…