LeetCode 面试经典150题 209.长度最小的子数组

题目

给定一个含有 n个正整数的数组和一个正整数 target

找出该数组中满足其总和大于等于target的长度最小的 连续子数组

[numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度**。** 如果不存在符合条件的子数组,返回 0

思路:双指针

代码

java 复制代码
class Solution {
    public int minSubArrayLen(int target, int[] nums) {
        int n = nums.length;
        int ans = n + 1;
        int left = 0;
        int sum = 0;
        for (int right = 0; right < n; right++) {
            sum += nums[right];
            while (sum - nums[left] >= target) {
                sum -= nums[left++];
            }
            if (sum >= target) 
                ans = Math.min(ans, right - left + 1);
        }
        return ans <= n ? ans : 0;
    }
}

性能:时间复杂度O(n) 空间复杂度O(1)

注意:长度不固定的叫做双指针,长度固定的叫做滑动窗口。习惯上而已,只是叫法不同,本质是同一个东西。

相关推荐
程序员一诺4 分钟前
【机器学习】嘿马机器学习(算法篇)第11篇:决策树算法,学习目标【附代码文档】
人工智能·python·算法·机器学习
小天努力学java20 分钟前
【面试系列】深入浅出 Spring
java·spring·面试
Evand J31 分钟前
平方根无迹卡尔曼滤波(SR-UKF)算法,用于处理三维非线性状态估计问题
算法
taoyong00135 分钟前
代码随想录算法训练营第十五天-二叉树-110.平衡二叉树
数据结构·算法
-芒果酱-40 分钟前
k-Means聚类算法 HNUST【数据分析技术】(2025)
算法·kmeans·聚类
渣渣威的仿真秀44 分钟前
Jensen-Shannon Divergence:定义、性质与应用
人工智能·算法·概率论
柒月的猫1 小时前
求和(2022蓝桥杯A组试题C)
c语言·算法·蓝桥杯
simple_ssn1 小时前
【蓝桥杯】压缩字符串
java·算法
-$_$-1 小时前
【LeetCode 面试经典150题】详细题解之哈希表篇
leetcode·面试·散列表
正在绘制中2 小时前
Java重要面试名词整理(八):RabbitMQ
java·面试·java-rabbitmq