LeetCode 之 长度最小的子数组

2023-09-18 23:33:18

算法模拟: Algorithm Visualizer

在线工具: C++ 在线工具

如果习惯性使用Visual Studio Code进行编译运行,需要C++11特性的支持,可参考博客:

VisualStudio Code 支持C++11插件配置


长度最小的子数组


LeetCode 长度最小的子数组

问题:

给定一个含有 n 个正整数的数组和一个正整数 target 。
找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr]
并返回其长度。如果不存在符合条件的子数组,返回 0 。

示例 1:
输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。

示例 2:
输入:target = 4, nums = [1,4,4]
输出:1

示例 3:
输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

思路:

可以使用滑动窗口的方法, 其实也是双指针的思想

定义两个指针 leftright ,分别表示子数组的左边界和右边界。

初始时,将 left right 都指向数组的第一个元素。

然后,我们不断增加 right 指针的位置,同时计算子数组的总和。

如果总和大于等于 target,则更新最小长度,并将 left 指针向右移动,缩小子数组的范围。

重复这个过程,直到 right 指针到达数组的末尾。

最后,返回最小长度即可。

C++示例

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        // 左边界指针
        int left = 0;
        // 初始化满足条件的最小长度
        int minLen = INT_MAX;
        // 子数组总和
        int curValue = 0;
        for (int right = 0; right < nums.size(); ++right) {
            curValue += nums[right];
            while(curValue >= target) {
                minLen = std::min(minLen, right - left + 1);
                curValue -= nums[left];
                left++;
            }
        }
        return (minLen != INT_MAX) ? minLen : 0;
    }
};

TypeScript示例

function minSubArrayLen(target: number, nums: number[]): number {
    let left:number = 0;
    let minLen: number = Infinity;
    let curValue: number = 0;
    for (let right = 0; right < nums.length; right++) {
        curValue += nums[right];
        while (curValue >= target) {
            minLen = Math.min(minLen, right - left + 1);
            curValue -= nums[left];
            left++;
        }
    }
    return (minLen !== Infinity) ? minLen : 0;
};

待定…

更多推荐

汉威科技亮相上海传感器展并发表主题演讲,智能传感器大有可为

9月15日,第8届中国(上海)国际传感器技术与应用展览会圆满落幕,该展会吸引了逾400家传感领域国内外的企业、100余家专业传感应用单位、500余位传感大咖共同参与,展会观众达30000人。作为全球三大传感器展之一的盛会,该展会也被称为全球传感器行业发展的风向标,而智能化则成为本次传感器的主题。展会同期举办的第八届智能

C++---链表

1、链表1.1、链表的结构每个链表开头都有一个头指针Head尾节点的指针域为NULL,用于判断此列表是否结束如果一个链表开始就为NULL,那么该链表为空链表链表中的先后不代表在真实内存中的位置,只是单纯的逻辑上关系1.2、创建链表我们首先利用结构体创建一个Student的结构体//利用链表创建3个学生的信息,学生信息包

【unity小技巧】Unity 存储存档保存——PlayerPrefs、JsonUtility和MySQL数据库的使用

文章目录前言PlayerPrefs一、基本介绍二、Demo三、优缺点JsonUtility一、基本使用二、Demo三、优缺点Mysql(扩展)完结前言游戏存档不言而喻,是游戏设计中的重要元素,可以提高游戏的可玩性,为玩家提供更多的自由和控制权。看完这篇文章就可以构建属于自己的存储系统了。PlayerPrefs它是一个仅

【Spring】数据导出为Excel的接口报java.io.IOException: UT010029: Stream is closed错误

数据导出为Excel的接口报java.io.IOException:UT010029:Streamisclosed错误实习时导师让写一个平台信息导出为Excel的功能,写完之后发现文件正常导出,但控制台一直报Streamisclosed错误。在网上找了大半天,都说是使用OutputStream时关闭了流导致的,这也确实

使用git-repo管理多个git仓库

step1:下载repogit-repo下载可在服务器端通过以下任一方式下载。gitclonehttps://gerrit.googlesource.com/git-repo(谷歌官方源)gitclonehttps://mirrors.tuna.tsinghua.edu.cn/git/git-repo(国内清华源)gi

JS模块化

JS模块化什么是模块化?将一个复杂的程序依据一定的规则(规范)封装成几个块(文件),并进行组合在一起。块的内部数据/实现是私有的,只是向外部暴露一些接口(方法)与外部其它模板通信。把所有的js代码写在一起,功能点不明确,耦合度不够,很难维护。模块化的优点避免命名冲突,减少命名空间污染更好的分离,按需加载更高复用性高可维

PgSQL-向量数据库插件-lantern

PgSQL-向量数据库插件-lantern即pgvector、pg_embedding后又一向量数据库扩展Lantern问世了。当然也为向量列提供了hnsw索引以加速ORDERBY...LIMIT查询。Lantern使用usearch实现hnsw。使用方法保留了标准PgSQL接口,兼容其生态工具。首先需要安装该插件:C

【Redis7】--4.事务、管道、发布和订阅

文章目录事务1.Redis事务2.Redis事务特性3.Redis事务命令3.1MULTI3.2EXEC3.3DISCARD3.4WATCH3.5UNWATCH4.不保证原子性4.1"全体连坐"4.2"冤头债主"5.事务执行流程管道1.pipeline的使用2.pipeline小总结发布和订阅1.常用命令1.1SUBS

LVGL移植win端模拟显示流畅解决方案-使用 SquareLine 生成前端 UI 文件

lvgl_port_win_vscode在win平台对lvgl方便的进行模拟显示,程序文件结构清晰,lvglwithSDL2,cmake构建,VsCode一键运行,使用SquareLine生成前端UI文件,win上直接跑。相比官方的lvgl移植到win端的几种方法SimulatoronPC—LVGLdocumentat

【STM32】WWDG—窗口看门狗

在一个设定好的区间进行喂狗与独立看门狗不同的是,独立看门狗只需要在计时到0之前喂狗。而窗口看门狗需要在设定好的区间内进行喂狗,否则进行reset。下限递减计数器不断的往下递减计数,当减到一个固定值0X40时还不喂狗的话,产生复位,这个值叫窗口的下限,是固定的值,不能改变。上限是窗口看门狗的计数器的值在减到某一个数之前喂

人工智能安全-6-SQL注入检测

0提纲概述SQL注入方法SQL注入的检测方法SQL语句的特征提取天池AI上的实践1概述SQLIA:SQLinjectionattackSQL注入攻击是一个简单且被广泛理解的技术,它把SQL查询片段插入到GET或POST参数里提交到网络应用。由于SQL数据库在Web应用中的普遍性,使得SQL攻击在很多网站上都可以进行。并

热文推荐