LeetCode Hot 100 - 子串 | 560.和为K的子数组、239.滑动窗口最大值、76.最小覆盖子串

560.和为K的子数组

前缀和+哈希表

要查找的子数组为连续的,可以由两个前缀和计算得出,满足题目的条件为preSum[i] - preSum[j-1] = k,所以我们可以用哈希表记录前缀和出现的次数,在遍历到位置 i 时计算出preSum[i] - k ,查看哈希表中是否有对应值,若有则取次数加入结果。

注意,用哈希表记录元素出现次数map.put(preSum , map.getOrDefault(preSum,0)+1);

java 复制代码
class Solution {
    public int subarraySum(int[] nums, int k) {
        int res = 0;
        int preSum = 0;
        HashMap<Integer,Integer> map = new HashMap<>();
        map.put(0,1);
        for(int i = 0 ; i<nums.length ; i++){
            preSum += nums[i];
            if(map.containsKey(preSum-k)){
                res += map.get(preSum-k);
            }
            map.put(preSum , map.getOrDefault(preSum,0)+1);
        }
        return res;
    }
}

239.滑动窗口最大值

利用单调队列,队列中保存索引值,并保持索引对应的元素递减,即如果加入的元素大于当前队尾元素,则弹出队尾元素(while),直到小于队尾元素或队列为空,放入该元素。

这样求滑动窗口的最大值仅需要 peekFirst 的值,每次循环要判断队首的元素索引如果不在窗口中了就要弹出。

注意:Deque的方法 offer、poll、First、Last

java 复制代码
class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int[] res = new int[nums.length-k+1];
        Deque<Integer> deque = new LinkedList<>();
        for(int i = 0 ; i<k ; i++){
            while(!deque.isEmpty() && nums[deque.peekLast()]<nums[i]){
                deque.pollLast();
            }
            deque.offerLast(i);
        }
        res[0] = nums[deque.peekFirst()];
        for(int i = k ; i<nums.length ; i++){
            while(!deque.isEmpty() && nums[deque.peekLast()]<nums[i]){
                deque.pollLast();
            }
            deque.offerLast(i);
            if(deque.peekFirst()<=i-k) deque.pollFirst();
            res[i-k+1] =  nums[deque.peekFirst()];
        }
        return res;
    }
}

76.最小覆盖子串(pass)

相关推荐
We་ct12 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程16 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮16 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说16 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove17 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung18 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了18 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL18 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰18 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商18 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法