算法---滑动窗口练习-1(长度最小的子数组)

长度最小的子数组

  • 1. 题目解析
  • 2. 讲解算法原理
  • 3. 编写代码

1. 题目解析

题目地址:长度最小的子数组

在这里插入图片描述

2. 讲解算法原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

首先,定义变量n为数组nums的长度,sum为当前子数组的和,len为最短子数组的长度,初始值为INT_MAX(表示无穷大)。

使用两个指针left和right来表示滑动窗口的左右边界,初始时两个指针都指向数组的起始位置。

进入循环,循环条件为right小于数组长度n。在每次循环中,执行以下操作:

a. 将当前right指向的元素加到sum中,表示将该元素纳入窗口。

b. 进入一个while循环,判断sum是否大于等于目标值target。如果是,则表示当前窗口的和已经满足要求。

c. 在while循环中,更新最短子数组的长度len,取当前len和窗口的长度(right-left+1)中的较小值。

d. 将窗口左边界的元素从sum中减去,并将左边界向右移动一位。

循环结束后,返回最短子数组的长度len。如果len的值仍然是INT_MAX,说明不存在满足要求的子数组,返回0。


3. 编写代码

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int n=nums.size(),sum=0,len=INT_MAX;for (int left=0,right=0;right<n;right++){sum+=nums[right];//进窗口while(sum>=target)//判断{len=min(len,right-left+1);//更新sum-=nums[left];//出窗口left++;}}return len==INT_MAX?0:len;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/740009.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javascript中的structuredClone()克隆方法

前言&#xff1a; structuredClone 是 JavaScript 的方法之一&#xff0c;用于深拷贝一个对象。它的语法是 structuredClone(obj)&#xff0c;其中 obj 是要拷贝的对象。structuredClone 方法将会创建一个与原始对象完全相同但是独立的副本。 案例&#xff1a; 当使用Web Work…

阿里巴巴按关键字搜索商品 API 返回值说明

item_search-按关键字搜索商品API测试工具 alibaba.item_search 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,…

Shadertoy内置函数系列 - mod 取模运算

mod函数返回x % 3的结果 先看一个挑战问题题目&#xff1a; Create a pattern of alternating black and red columns, with 9 columns of each color. Then, hide every third column that is colored red.The shader should avoid using branching or conditional statemen…

2024年最新阿里云和腾讯云云服务器价格租用对比

2024年阿里云服务器和腾讯云服务器价格战已经打响&#xff0c;阿里云服务器优惠61元一年起&#xff0c;腾讯云服务器61元一年&#xff0c;2核2G3M、2核4G、4核8G、4核16G、8核16G、16核32G、16核64G等配置价格对比&#xff0c;阿腾云atengyun.com整理阿里云和腾讯云服务器详细配…

C语言分支和循环总结

文章目录 概要结构介绍不同结构的语句简单运用小结 概要 C语言中分为三种结构&#xff1a;顺序结构&#xff0c;选择结构&#xff0c;循环结构 结构介绍 顺序结构就是从上到下&#xff0c;从左到右等等&#xff1b;选择结构可以想象是Y字路口就是到了一个地方会有不同的道路…

Redis事务为什么不支持原子性

Redis事务提供了一种将多个命令打包&#xff0c;然后按顺序执行的机制。使用MULTI命令开始事务&#xff0c;接着输入需要队列化的命令&#xff0c;最后使用EXEC命令提交整个事务。尽管Redis事务可以保证一系列命令被连续执行&#xff0c;没有其他客户端命令插入其中执行&#x…

每日OJ题_路径dp②_力扣63. 不同路径 II

目录 力扣63. 不同路径 II 解析代码 力扣63. 不同路径 II 63. 不同路径 II 难度 中等 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;…

多媒体技术2-颜色空间

颜色空间是一种用于表示和描述颜色的数学模型。它是由颜色分量和坐标系组成的。常见的颜色空间有RGB、CMYK、HSV等。 RGB颜色空间&#xff1a;RGB是红、绿、蓝三个颜色分量的缩写。在RGB颜色空间中&#xff0c;每个颜色分量的取值范围是0到255&#xff0c;表示了红、绿、蓝三个…

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Select)

提供下拉选择菜单&#xff0c;可以让用户在多个选项之间选择。 说明&#xff1a; 该组件从API Version 8开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 无 接口 Select(options: Array<SelectOption>) 参数&#xff1a;…

golang中fallthrough简介及用法

什么是fallthrough&#xff1f; fallthrough是golang中的一个关键字&#xff0c;它用于在switch语句中控制代码的执行流程。通常情况下&#xff0c;当一个case分支匹配成功后&#xff0c;switch语句就会结束&#xff0c;不会继续执行后面的case分支。但是&#xff0c;如果在一…

git撤回代码提交commit或者修改commit提交注释

执行commit后&#xff0c;还没执行push时&#xff0c;想要撤销之前的提交commit 撤销提交 使用命令&#xff1a; git reset --soft HEAD^命令详解&#xff1a; HEAD^ 表示上一个版本&#xff0c;即上一次的commit&#xff0c;也可以写成HEAD~1 如果进行两次的commit&#xf…

爬虫(六)

复习回顾: 01.浏览器一个网页的加载全过程1. 服务器端渲染html的内容和数据在服务器进行融合.在浏览器端看到的页面源代码中. 有你需要的数据2. 客户端(浏览器)渲染html的内容和数据进行融合是发生在你的浏览器上的.这个过程一般通过脚本来完成(javascript)我们通过浏览器可以…

算法打卡day15|二叉树篇04|110.平衡二叉树、257. 二叉树的所有路径、404.左叶子之和

算法题 Leetcode 110.平衡二叉树 题目链接:110.平衡二叉树 大佬视频讲解&#xff1a;平衡二叉树视频讲解 个人思路 可以用递归法&#xff0c;计算左右子树的高度差&#xff0c;当超过1时就不为平衡二叉树了&#xff1b; 解法 回顾一下二叉树节点的深度与高度&#xff1b; …

Python学习:基础语法

版本查看 python --version编码 默认情况下&#xff0c;Python 3 源码文件以 UTF-8 编码&#xff0c;所有字符串都是 unicode 字符串。 特殊情况下&#xff0c;也可以为源码文件指定不同的编码&#xff1a; # -*- coding: cp-1252 -*-标识符 第一个字符必须是字母表中字母或…

rt-thread组件之audio组件(结合mp3player包使用)

前言 继上一篇RT-Thread组件之Audio框架i2s驱动的编写的编写&#xff0c;应用层使用rt-thread软件包里面的wavplayer组件以及 rt-thread组件之audio组件(结合wavplayer包使用)的文章本篇使用的是 mp3player软件包&#xff0c;与wavplayer设计框架基本上是一样的&#xff0c;只…

C语言真假之争

实验理论依据: \0、NULL、0和0在C语言中表示的意义是不同的&#xff1a; \0&#xff1a;这是一个空字符&#xff0c;ASCII值为0。常用于字符串结束的标志。 NULL&#xff1a;这是一个宏&#xff0c;表示空指针&#xff0c;用于初始化指针变量。 0&#xff1a;这是数字0&#…

LeetCode454 四数相加

给你四个整数数组 nums1、nums2、nums3 和 nums4 &#xff0c;数组长度都是 n &#xff0c;请你计算有多少个元组 (i, j, k, l) 能满足&#xff1a; 0 < i, j, k, l < n nums1[i] nums2[j] nums3[k] nums4[l] 0 示例 1&#xff1a; 输入&#xff1a;nums1 [1,2], nu…

java-单列集合-set系列

set集合继承collection,所以API都差不多&#xff0c;我就不多加介绍 直接见图看他们的特点 我们主要讲述的是set系列里的HashSet、LinkedHashSet、TreeSet HashSet HashSet它的底层是哈希表 哈希表由数组集合红黑树组成 特点&#xff1a;增删改查都性能良好 哈希表具体是…

网络安全攻击数据的多维度可视化分析

简介 本研究项目通过应用多种数据处理与可视化技术&#xff0c;对网络安全攻击事件数据集进行了深度分析。首先&#xff0c;利用Pandas库读取并预处理数据&#xff0c;包括检查缺失值、剔除冗余信息以及将时间戳转化为日期时间格式以利于后续时间序列分析。 研究步骤 数据分析…

控件交互的优劣势--自动窗帘系统

控件交互在图形用户界面&#xff08;GUI&#xff09;设计中具有明显的优劣势。以下是对这些优劣势的详细分析 一&#xff0c;控件交互的优势 (1)直观性&#xff1a;控件交互往往遵循用户习惯和直觉&#xff0c;使得用户无需额外学习即可理解并操作。例如&#xff0c;大多数用户…