前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基础算法——前缀和详解

基础算法——前缀和详解

作者头像
秋名山码神
发布2022-12-13 14:50:20
2970
发布2022-12-13 14:50:20
举报
文章被收录于专栏:码神随笔

秋名山码民的主页 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 🙏作者水平很有限,如果发现错误,一定要及时告知作者

前言

由于有些读者朋友私聊我,希望出几期基础算法的讲解,kmp,dp,哈希,搜索,贪心等对初学者还是不太友好,所以我打算更新几期基础算法合集,没办法谁让我宠粉丝呢?彦祖,热巴说你呢,快关注!

目录大致如下:

排序(十大排序)——已经讲过 高精度算法 从0->1入门双指针 前缀和 二分 位运算 区间合并

何为前缀和算法?

前缀和算法,属于基础算法,一般来说没有固定的模板,但是其思路值得借鉴,我们来看一个案例就懂了 一维前缀和最基本的用法

Si = a1+a2+a3+…+ai

如何求Si?

传统思路: 暴力枚举,代码如下

代码语言:javascript
复制
for(int i = 1; i <= n; i++){
	//直接累加
	s+=a[i];
	//自己设置退出条件
	
}

但是我们不满足于当前的时间复杂度O(n)想快一点,随便求一个区间前缀和,假设这个区间就为S[ l,r ] 这时就要请出我们高中所学的等差数列,像这样:

Sr = a1+a2+a3+…+al-1+al…+ar Sl-1 = a1+a2+a3+…+al-1

俩个相减

在这里插入图片描述
在这里插入图片描述

上图不难看出所得就是S[ l,r ]的区间和

作用

那么大家知道了什么是前缀和,一个东西的存在必然是有他的作用的,不然学他干嘛?

在这里插入图片描述
在这里插入图片描述

作用: 快速求一段和,上面暴力算法时间复杂度为O(n),而现在的时间复杂度可降为O(1)

具体实现: 求s[ l, r ]的区间和

代码语言:javascript
复制
for(int i = 1; i <= n; i++){
	s[i] = s[i-1] + a[i];
}
printf("%d",s[r] - s[l-1]);

值得注意的一点是,我们一般将S[0] = 0,原因如下: 假设我们需要计算S【1,10】,那么S10 - S0可以直接得出,Sr - S(l-1)

最后

看在博主这么努力,熬夜肝的情况下,给个免费的三连吧!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 何为前缀和算法?
  • 作用
  • 最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档