【LeetCode 前缀和 + 哈希表】LC_560_和为K的子数组

文章目录

      • [1. 和为K的子数组🆗](#1. 和为K的子数组🆗)

1. 和为K的子数组🆗

题目链接🔗


  • 🐧解题思路前缀和 + 哈希表

🍎 设i为数组中的任意位置,⽤ sum[i] 表⽰ [0, i] 区间内所有元素的和。

🍎 想知道有多少个「以 i 为结尾的和为 k 的⼦数组」,就要找到有多少个起始位置为 x1, x2, x3... 使得 [x, i] 区间内的所有元素的和为 k 。那么[0, x]区间内的和是不是就是sum[i] - k 了。

于是问题就变成:

找到在[0, i - 1]区间内,有多少前缀和等于sum[i] - k的即可。

我们不⽤真的初始化⼀个前缀和数组,因为我们只关⼼在i位置之前,有多少个前缀和等于
sum[i] - k 。因此,我们仅需⽤⼀个哈希表,⼀边求当前位置的前缀和,⼀边存下之前每⼀种

前缀和出现的次数。


cpp 复制代码
class Solution
{
public:
 int subarraySum(vector<int>& nums, int k) 
 {
	 unordered_map<int, int> hash; // 统计前缀和出现的次数
	 
	 // 为什么初始值 hash[0] = 1呢?
	 // 因为:有可能 sum == k, 我们统计 hash.count(sum - k)统计的是当前元素之前的值,没有统计千
	 // 前缀和刚好等于 k 的情况
	 hash[0] = 1;
	 
	 int sum = 0, ret = 0;
	 for(auto x : nums)
	 {
		 sum += x; // 计算当前位置的前缀和
		 if(hash.count(sum - k)) ret += hash[sum - k]; // 统计个数
		 hash[sum]++;
	 }
	 return ret;
 }
};
相关推荐
csdn_aspnet7 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_6294947310 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
小羊在睡觉14 小时前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
大大杰哥15 小时前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
叶小鸡16 小时前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
凌波粒16 小时前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode
一只小逸白18 小时前
LeetCode Go 常用函数速查表
linux·leetcode·golang
Tisfy19 小时前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
承渊政道19 小时前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
人道领域19 小时前
【LeetCode刷题日记】654.最大二叉树:递归算法详解
java·算法·leetcode