和为K的子数组,前缀和,你还不会吗?

本文介绍了如何利用前缀和优化数组区间和的计算,详细解析了在LeetCode中遇到的和为K的子数组问题。通过创建前缀和数组并转换问题思路,使用HashMap进行优化,将时间复杂度降低到O(n),显著提升了算法效率。
摘要由CSDN通过智能技术生成

前缀和

前缀和适合在数组中频繁的求某一段区间的和

如果当前你要完成一个需求,给你一个数组nums,然后频繁的给你两个数字i和j,叫你求nums[i]到nums[j]区间的和。

按照我们一般的思维就是从i开始循环,循环到j,然后将其中的nums加起来,最后返回,这样子每次查找的渐进时间复杂度都是O(n)

但如果我们使用前缀和来做会是什么样子的呢?

首先我们创建一个保存前缀和的数组

int[] preNums = new int[nums.length+1];
preNums [0] = 0;
for(int i=0; i<nums.length; i++){
    preNums[i+1] = preNums[i]+nums[i];
}

假设当前nums数组的值为:{2,5,9,6,7},则对应的前缀数组为

那么,对于我们求nums[i]到nums[j]的区间和,就相当与用preNums[j+1]-preNums[i]

下面我们来看一个leetcode的原题,和为K的子数组

利用我们上面学过的知识,我们很容易写出下面这个代码

c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值