560 和为k的子数组

解题思路:
\qquad 一开始看到连续非空序列,会想到是不是可以用双指针表示一个区间,然后通过一次遍历找出所有可能的区间,但看到元素的取值区间就知道行不通,这个方法仅适用于数组元素大于等于0的情况。若数字是负数,随着区间长度的增加,其和的值不一定会增加,因而只能把所有的区间遍历一遍去找。

\qquad 巧妙的解法在于转化,将连续序列的和,转化成两个序列和的值之差(感觉有点dp的影子)。

\qquad 对于每个位置i,记录[0, i]区间内所有元素的和,因此sum[j+1,i] = sum[0,i] - sum[0,j]。这样,题目从一个区间问题,变成了一个a - b = k这种类似两数之和的问题了,妙啊。这些元素之和以及个数可以通过map记录,实现 O ( 1 ) O(1) O(1)查找。而且由于j < i,而在一次遍历过程中,map只能存储当前位置之前的累加和,所以一举两得,只用一次遍历即可解决。

cpp 复制代码
	int subarraySum(vector<int>& nums, int k) {
        int ans = 0, pre = 0;
        unordered_map<int,int> m;
        m[0] = 1;

        for(auto n : nums)
        {
            pre += n;
            if(m.find(pre - k) != m.end())
            {
                ans += m[pre - k];
            }
            m[pre]++;
        }

        return ans;
    }
相关推荐
如何原谅奋力过但无声24 分钟前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
jf加菲猫1 小时前
第21章 Qt WebEngine
开发语言·c++·qt·ui
码农-阿杰2 小时前
深入理解 synchronized 底层实现:从 HotSpot C++ 源码看对象锁与 Monitor 机制
开发语言·c++·
Szime2 小时前
深智微IC华润微代理:MCU选型与工业控制方案推荐
c++
叼烟扛炮3 小时前
C++ 知识点18 内部类
开发语言·c++·算法·内部类
汉克老师3 小时前
GESP5级C++考试语法知识(十五、分治算法(二))
c++·算法·排序算法·分治算法·gesp5级·gesp五级
汉克老师3 小时前
GESP6级C++考试语法知识(五、格雷码)
c++·算法·位运算·异或·gesp6级·gesp六级·格雷码
程序leo源4 小时前
C语言知识总结
c语言·开发语言·c++·经验分享·笔记·青少年编程·c#
沫璃染墨4 小时前
二叉搜索树完全指南:从核心原理到增删查改全实现
开发语言·c++
‎ദ്ദിᵔ.˛.ᵔ₎4 小时前
C++哈希表
数据结构·c++·散列表