力扣面试150 长度最小的子数组 滑动窗口

Problem: 209. 长度最小的子数组

参考题解

滑动窗口

Java 复制代码
class Solution {
    public int minSubArrayLen(int target, int[] nums) {
        int n = nums.length;
        int ans = n + 1;
        int sum = 0; // 子数组元素和
        int left = 0; // 子数组左端点
        for (int right = 0; right < n; right++) { // 枚举子数组右端点
            sum += nums[right];
            while (sum >= target) { // 满足要求
                ans = Math.min(ans, right - left + 1);
                sum -= nums[left++]; // 左端点右移
            }
        }
        return ans <= n ? ans : 0;
    }
}
相关推荐
国科安芯9 分钟前
AS32S601商业航天级抗辐照MCU芯片:架构设计与技术特性研究
单片机·嵌入式硬件·算法·安全·架构·risc-v
罗超驿30 分钟前
6.Java多线程详解:Thread类、线程属性与start()方法深度解析
java·开发语言·面试·java-ee
菜菜的顾清寒36 分钟前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
圣保罗的大教堂36 分钟前
leetcode 2657. 找到两个数组的前缀公共数组 中等
leetcode
名字不好奇37 分钟前
大模型的思考模式:它真的在“想“吗?
人工智能·算法
Run_Teenage1 小时前
算法模板:输入输出,并查集
java·开发语言·算法
高一学习c++会秃头吗1 小时前
操作系统内存块分配算法
算法
洛水水1 小时前
【力扣100题】57.合并区间
算法·leetcode
圣保罗的大教堂1 小时前
leetcode 33. 搜索旋转排序数组 中等
leetcode
玉树临风ives1 小时前
atcoder ABC 458 题解
数据结构·c++·算法