每日一题:Leetcode560.和为K的子数组(前缀和+哈希)
2023-12-13 07:35:46
题目描述:
给你一个整数数组?nums
?和一个整数?k
?,请你统计并返回?该数组中和为?k
?的子数组的个数?。
子数组是数组中元素的连续非空序列。
示例 1:
输入:nums = [1,1,1], k = 2 输出:2
示例 2:
输入:nums = [1,2,3], k = 3 输出:2
提示:
1 <= nums.length <= 2 * 104
-1000 <= nums[i] <= 1000
-107 <= k <= 107
思路:遍历数组使用一个变量presum记录当前节点的前缀和,用另一个指针去遍历该位置前面的数组,找到和为k的子数组,但是这样的话时间复杂度就是o(n^2)
优化:采用哈希表记录前缀和,把找和为k的子数组转化为在哈希表中找和为presum-k的前缀和数组,如果哈希表中存在则将结果ret加上该前缀和所对应的哈希值(即出现的次数),再将该位置的前缀和放入哈希表中。注意特殊情况,如果presum==k则将ret++。
代码实现:
class Solution {
public:
int subarraySum(vector<int>& nums, int k) {
int presum=0,ret=0;
unordered_map<int,int> hash;
for(auto e: nums)
{
presum+=e;
if(hash.count(presum-k))
ret+=hash[presum-k];
if(presum==k)
ret++;
hash[presum]++;
}
return ret;
}
};
文章来源:https://blog.csdn.net/m0_73865858/article/details/134953416
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!