news 2026/5/27 3:49:33

力扣 长度最小的子数组

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣 长度最小的子数组

一、题目概述

给定一个含有n正整数的数组nums和一个正整数target
请找出该数组中满足其和 ≥ target 的长度最小的连续子数组,并返回其长度。
如果不存在符合条件的子数组,则返回0


二、问题分析

1, 连续子数组 + 求最小长度

题目要求的是:

  • 连续子数组(不是子序列)

  • 和 ≥ target

  • 长度最小

这三个条件共同决定了本题非常适合使用滑动窗口(双指针)方法。


2, 为什么不能暴力枚举?

暴力做法是:

  • 枚举所有子数组

  • 计算每个子数组的和

时间复杂度为:

O(n²)

在数据规模较大时必然超时 ❌。


三、滑动窗口核心思想

滑动窗口的本质

维护一个区间[left, right],并保证:

  • right向右扩展:增加窗口内的元素

  • 当窗口内的和 ≥ target时:

    • 尝试移动left缩小窗口

    • 更新最小长度


适用条件

⚠️本题能够使用滑动窗口的关键前提是:

数组中的元素全部为正整数

因为只有正整数,窗口右移时,区间和才会单调递增
左移时才会单调递减

四、算法步骤详解

  1. 初始化:

    • left = 0

    • sum = 0

    • ans = n + 1(表示未找到)

  2. right0开始遍历数组:

    • nums[right]加入sum

  3. sum >= target时:

    • 更新最小长度:ans = min(ans, right - left + 1)

    • 移动left,缩小窗口:sum -= nums[left] left++

  4. 遍历结束: 如果ans未更新,返回0否则返回ans

五、代码

class Solution { public: int minSubArrayLen(int target, vector<int>& nums) { int n = nums.size(); int left = 0; int sum = 0; int ans = n + 1; for (int right = 0; right < n; right++) { sum += nums[right]; while (sum >= target) { ans = min(ans, right - left + 1); sum -= nums[left]; left++; } } return ans == n + 1 ? 0 : ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 4:55:16

1小时搭建数据泄漏监控原型:快马平台实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 在InsCode平台快速开发数据泄漏监控原型&#xff0c;需求&#xff1a;1. 用户输入邮箱 2. 检查预设的模拟泄露数据库 3. 返回简单JSON结果 4. 基础前端展示 5. 可一键部署。使用Pyt…

作者头像 李华
网站建设 2026/5/26 6:10:10

Gemini 3 + Nano Banana Pro 正在终结“平民美学”的幻觉

在人类文明的历史长河中&#xff0c;美学权力的每一次变迁都伴随着资源的重新分配。从教会对艺术的垄断&#xff0c;到工业时代对设计的普及&#xff0c;我们曾天真地以为&#xff0c;随着 AI 技术的爆发&#xff0c;人类将迎来一个“美学大同”的乌托邦。 然而&#xff0c;20…

作者头像 李华
网站建设 2026/5/26 6:09:57

3分钟用软连接搭建开发环境原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个快速环境配置脚本&#xff0c;使用Linux软连接搭建开发环境原型。功能包括&#xff1a;1. 一键创建常用工具软连接 2. 设置项目目录结构 3. 配置开发环境快捷方式 4. 初始化…

作者头像 李华
网站建设 2026/5/26 6:09:58

1小时搞定:用快马快速验证防抖节流方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速构建一个防抖节流方案验证平台&#xff0c;包含&#xff1a;1. 可配置参数的防抖/节流函数生成器&#xff1b;2. 多种测试场景模拟&#xff08;输入、滚动、点击等&#xff09;…

作者头像 李华
网站建设 2026/5/26 16:43:14

BEMD分解效果示例](https://example.com/bemd_demo.png

二维经验模式分解(BEMD)算法在图像上的应用Matlab实现代码质量极高&#xff0c;方便学习和修改数据使用。&#xff08;假装这里有张图&#xff0c;实际写代码的时候自己生成吧&#xff09;图像处理领域总有些怪东西让人又爱又恨&#xff0c;二维经验模态分解(BEMD)就是其中之一…

作者头像 李华