当前位置: 首页 > article >正文

【滑动窗口】LeetCode 209题解 | 长度最小的子数组

长度最小的子数组

  • 前言:滑动窗口
  • 一、题目链接
  • 二、题目
  • 三、算法原理
    • 解法一:暴力枚举
    • 解法二:利用单调性,用滑动窗口解决问题
      • 那么怎么用滑动窗口解决问题?
      • 分析滑动窗口的时间复杂度
  • 四、编写代码

前言:滑动窗口

有关于滑动窗口的5个知识点:

  1. 什么是滑动窗口?—— 同向双指针
  2. 什么时候用滑动窗口?—— 单调性
  3. 为什么能够用滑动窗口正确解决问题?—— 利用单调性,规避了很多没必要的枚举行为。
  4. 滑动窗口的时间复杂度?—— O(n)
  5. 如何书写滑动窗口的代码?

一、题目链接

长度最小的子数组

二、题目

在这里插入图片描述

三、算法原理

解法一:暴力枚举

枚举出所有的子数组求和,枚举出一个结果的同时更新最小长度。

在这里插入图片描述

时间复杂度是O(n^3):

  1. 枚举子数组:确定子数组左右区间,O(n^2)
  2. 求和:遍历左右区间内的所有元素求和,O(n)

暴力枚举优化为O(n^2):定义完left后,定义变量sum计算right右移过程中区间内的所有元素的和。避免再遍历一遍求和。sum初始化为0,sum直接继续加即可。例如:

在这里插入图片描述


"正整数"是一个优化的方向。

对于 ≥ 0 的数,作加法运算的单调性性质:加一起求和的数越多,那么和越大。

利用这个单调性作优化:先模拟优化后的暴力枚举方法。

前面的枚举过程:

在这里插入图片描述

当枚举出 sum >= target 的子数组,更新长度 len。按照暴力枚举,right会继续向后找符合要求的子数组。虽然sum >= target,但是len在变大,与题中要求是找长度最小的不符:

在这里插入图片描述

规律1:找到一个结果后,right后面的元素一定不是最终结果,right不用向后枚举了。

接着再依次固定left,依据暴力枚举,right需回退再枚举:

在这里插入图片描述

当枚举到下图,发现right不用回退且sum不用挨个相加,直接用上一个sum减去上一个固定的left值即可:

在这里插入图片描述

规律2:当找到一个结果后,left右移一步且right不用回退,此时的区间内的sum <= target。为什么right不用回退?若right回退,计算sum的过程中,还会在上一次停止的地方停止或继续向后走。

根据规律1、2,得出解法二:

解法二:利用单调性,用滑动窗口解决问题

上面的分析得出,left与right两个指针都是向右移动的,即同向双指针,也就是滑动窗口。滑动窗口维护的是一个区间里的信息,本题里维护的就是一段区间里的和。在两个指针都从左向右移动的过程中,很像一个窗口在数组里从左向右滑动。
在这里插入图片描述


那么怎么用滑动窗口解决问题?

  1. 初始化滑动窗口的左右端点:left = 0, right = 0;
  2. 进窗口
  3. 判断
    出窗口

2、3步骤循环。这一循环里还有"更新结果"一步,这一步在哪执行要具体分析,可能在进窗口时更新,可能在出窗口前更新,还可能在整个判断步骤结束后更新。


在这里插入图片描述
为什么出窗口后还要再判断?因为出窗口后只出了一个元素,这个窗口区间内的所有元素之和可能还是≥target的。

用滑动窗口模拟过程:

在这里插入图片描述

right到最后是循环终止的条件,最终结果就是最短长度。


分析滑动窗口的时间复杂度

进窗口、判断的整个过程有个循环,判断过程也有个循环,循环嵌套,那么时间复杂度是O(n^2)吗?这里不要看代码分析时间复杂度。要依据实际情况分析:每一步操作仅让right/left向后移动一步,直到让right移动到最后为止。

最差情况:right先一步一步移动到最后一个元素停止,left再一步一步移动到最后一个元素停止,最后right再移动到最后循环结束,因此总的操作数:n + n == 2n,时间复杂度是O(n)

在这里插入图片描述

四、编写代码

注意初始化变量len时,若把len初始化为0,因为求min,所以最后结果一定都是0。因此就要把len初始化大一点。

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

相关文章:

【滑动窗口】LeetCode 209题解 | 长度最小的子数组

长度最小的子数组 前言&#xff1a;滑动窗口一、题目链接二、题目三、算法原理解法一&#xff1a;暴力枚举解法二&#xff1a;利用单调性&#xff0c;用滑动窗口解决问题那么怎么用滑动窗口解决问题&#xff1f;分析滑动窗口的时间复杂度 四、编写代码 前言&#xff1a;滑动窗口…...

在RK3588上使用NCNN和Vulkan加速ResNet50推理全流程

在RK3588上使用NCNN和Vulkan加速ResNet50推理全流程 前言:为什么需要关注移动端AI推理一、环境准备与框架编译1.1 获取NCNN源码1.2 安装必要依赖1.3 编译NCNN二、模型导出与转换2.1 生成ONNX模型2.2 转换NCNN格式三、模型量化加速3.1 生成校准数据3.2 执行量化操作四、性能测试…...

【ant design】ant-design-vue 4.0实现主题色切换

官网&#xff1a;Ant Design Vue — An enterprise-class UI components based on Ant Design and Vue.js 我图方便&#xff0c;直接在 app.vue 中加入的 <div class"app-content" v-bind:class"appOption.appContentClass"><a-config-provider…...

Android 图片自动拉伸不变形,点九

要让 UI 设计师 制作 Android 用的点九图&#xff08;.9.png&#xff09;&#xff0c;可以按照以下流程和要求进行&#xff1a; &#x1f9e9; 一、什么是点九图&#xff1f; 点九图&#xff08;NinePatch&#xff09;是一种特殊的 PNG 图像&#xff0c;用于在 Android 中根据…...

电子电路:什么是色环电阻器,怎么识别和计算阻值?

识别和计算色环电阻的阻值需要掌握颜色编码规则和基本步骤。以下是具体方法及窍门: 一、色环电阻的基本规则 色环数量: 4环电阻:前2环为有效数字,第3环为倍乘(10ⁿ),第4环为误差。5环电阻:前3环为有效数字,第4环为倍乘,第5环为误差。6环电阻(较少见):前3环为有效数…...

LeetCode Hot100刷题——轮转数组

56. 轮转数组 给定一个整数数组 nums&#xff0c;将数组中的元素向右轮转 k 个位置&#xff0c;其中 k 是非负数。 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右轮转 3 步: …...

Python绘制南丁格尔玫瑰图:从入门到实战

Python绘制南丁格尔玫瑰图&#xff1a;从入门到实战 引言 南丁格尔玫瑰图&#xff08;Nightingale Rose Chart&#xff09;&#xff0c;也被称为极区图&#xff08;Polar Area Chart&#xff09;&#xff0c;是一种独特的数据可视化方式。这种图表由弗洛伦斯南丁格尔&#xff…...

概率与期望总结

一、概率 概念&#xff1a;无需多言&#xff1b;几个公式&#xff08; Ω \Omega Ω 表示整个样本空间&#xff09;&#xff1a; 以下公式均有 A , B ⊆ Ω , 且 P ( A ) , P ( B ) > 0. P ( A ∪ B ) P ( A ) P ( B ) − P ( A ∩ B ) , P ( A ∣ B ) P ( A B ) P ( B…...

炼丹学习笔记3---ubuntu2004部署运行openpcdet记录

前言 环境 cuda 11.3 python 3.8 ubuntu2004 一、cuda环境检测 ylhy:~/code_ws/OpenPCDet/tools$ nvcc -V nvcc: NVIDIA (R) Cuda compiler driver Copyright (c) 2005-2021 NVIDIA Corporation Built on Sun_Mar_21_19:15:46_PDT_2021 Cuda compilation tools, release 11.3…...

深入解析BGP路由反射器与联邦:突破IBGP全连接限制的两种方案

一、引言&#xff1a;大型BGP网络的挑战 在大型BGP网络架构中&#xff0c;传统的IBGP全连接架构会带来严重的扩展性问题。当网络中存在N台路由器时&#xff0c;需要维护N*(N-1)/2个IBGP连接&#xff0c;这对设备资源和运维管理都是巨大挑战。本文将深入解析两种主流解决方案&a…...

QT设置MySQL驱动

QSqlDatabase: QMYSQL driver not loaded QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7 第一步&#xff1a;下载MySQL https://dev.mysql.com/downloads/mysql/ 解压缩下载的安装包&#xff0c;其目录结构如下所示&#xff1a; 第二…...

String的一些固定程序函数

append reverse length toString...

3.2/Q2,Charls最新文章解读

文章题目&#xff1a;Transition of nighttime sleep duration and sleep quality with incident cardiovascular disease among middle-aged and older adults: results from a national cohort study DOI&#xff1a;10.1186/s13690-025-01577-5 中文标题&#xff1a;中老年人…...

大麦(Hordeum vulgare)中 BAHD 超家族酰基转移酶-文献精读129

Systematic identification and expression profiles of the BAHD superfamily acyltransferases in barley (Hordeum vulgare) 系统鉴定与大麦&#xff08;Hordeum vulgare&#xff09;中 BAHD 超家族酰基转移酶的表达谱分析 摘要 BAHD 超家族酰基转移酶在植物中催化和调控次…...

docker迅雷自定义端口号、登录用户名密码

在NAS上部署迅雷&#xff0c;确实会带来很大的方便。但是目前很多教程都是讲怎么部署docker迅雷&#xff0c;鲜有将自定义配置的方法。这里讲一下怎么部署&#xff0c;并重点讲一下支持的自定义参数。 一、部署docker 在其他教程中&#xff0c;都是介绍的如下命令&#xff0c…...

中国30米年度土地覆盖数据集及其动态变化(1985-2022年)

中文名称 中国30米年度土地覆盖数据集及其动态变化(1985-2022年) 英文名称&#xff1a;The 30 m annual land cover datasets and its dynamics in China from 1985 to 2022 CSTR:11738.11.NCDC.ZENODO.DB3943.2023 DOI 10.5281/zenodo.8176941 数据共享方式&#xff1a…...

3D个人简历网站 5.天空、鸟、飞机

1.显示天空 models下新建文件Sky.jsx Sky.jsx // 从 React 库中导入 useRef 钩子&#xff0c;用于创建可变的 ref 对象 import { useRef } from "react"; // 从 react-three/drei 库中导入 useGLTF 钩子&#xff0c;用于加载 GLTF 格式的 3D 模型 import { useGLT…...

STM32IIC实战-OLED模板

STM32IIC实战-OLED模板 一&#xff0c;SSD1306 控制芯片1&#xff0c; 主要特性2&#xff0c;I2C 通信协议3&#xff0c; 显示原理4&#xff0c; 控制流程5&#xff0c; 开发思路 二&#xff0c;HAL I2C API 解析I2C 相关 API1&#xff0c;2&#xff0c;3&#xff0c;4&#xf…...

Sparse4D运行笔记

Sparse4D有三个版本&#xff0c;其中V1和V2版本的官方文档中环境依赖写得比较模糊且依赖库有版本冲突。 1. Sparse4D V1 创建环境 conda create sparse4dv1 python3.8 激活环境 conda activate sparse4dv1 安装torch, torchvision, torchaudio pip install torch1.13.0c…...

Redis设计与实现——分布式Redis

Redis Sentinel&#xff08;哨兵&#xff09; Sentinel 的工作机制 故障检测&#xff08;Failure Detection&#xff09; 主观下线&#xff08;Subjective Down&#xff09;&#xff1a;单个 Sentinel 实例检测到主节点在30 秒内无响应&#xff0c;标记其为 SDOWN。 客观下线…...

多指标组合策略

该策略(MultiConditionStrategy)是一种基于多种技术指标和市场条件的交易策略。它通过综合考虑多个条件来生成交易信号,从而决定买入或卖出的时机。 以下是对该策略的详细分析: 交易逻辑思路 1. 条件1:星期几和价格变化判断 - 该条件根据当前日期是星期几以及价格的变化…...

c#车检车构客户管理系统软件车辆年审短信提醒软件

# CMS_VehicleInspection 车检车构客户管理系统软件车辆年审短信提醒软件 # 开发背景 软件是给泸州某公司开发的车检车构客户管理系统软件。用于在车检年审到期前一个月给客户发送车检短信提醒 # 功能描述 主要功能&#xff1a;车辆年审前一个月给客户发年审短信提醒&#xf…...

Java爬虫能处理京东商品数据吗?

Java爬虫完全可以处理京东商品数据。通过Java爬虫技术&#xff0c;可以高效地获取京东商品的详细信息&#xff0c;包括商品名称、价格、图片、描述等。这些信息对于市场分析、选品上架、库存管理和价格策略制定等方面具有重要价值。以下是一个完整的Java爬虫示例&#xff0c;展…...

通俗版解释CPU、核心、进程、线程、协程的定义及关系

通俗版解释&#xff08;比喻法&#xff09; 1. CPU 和核心 CPU 一个工厂&#xff08;负责干活的总部&#xff09;。核心 工厂里的车间&#xff08;比如工厂有4个车间&#xff0c;就能同时处理4个任务&#xff09;。 2. 进程 进程 一家独立运营的公司&#xff08;比如一家…...

大语言模型 11 - 从0开始训练GPT 0.25B参数量 MiniMind2 准备数据与训练模型 DPO直接偏好优化

写在前面 GPT&#xff08;Generative Pre-trained Transformer&#xff09;是目前最广泛应用的大语言模型架构之一&#xff0c;其强大的自然语言理解与生成能力背后&#xff0c;是一个庞大而精细的训练流程。本文将从宏观到微观&#xff0c;系统讲解GPT的训练过程&#xff0c;…...

USRP 射频信号 采集 回放 系统

USRP 射频信号采集回放系统 也可以叫做&#xff1a; 利用宽带RF录制和回放系统实现6G技术研究超宽带射频信号采集回放系统使用NI USRP平台实现射频信号录制和回放操作演示USRP也能实现多通道宽带信号流盘回放了&#xff01; 对于最简单的实现方法就是使用LabVIEW进行实现 采…...

【skywalking】index“:“skywalking_metrics-all“},“status“:404}

skywalking 启动报错 java.lang.RuntimeException: {"error":{"root_cause":[{"type":"index_not_found_exception","reason":"no such index [skywalking_metrics-all]","resource.t ype":"inde…...

handsome主题美化及优化:10.1.0最新版 - 1

文章目录 前言右侧导航栏主题标题居中页面两侧框架留白间距handsome 原生入站提示评论一键赞、踩、打卡时光机头像圆形logo 扫光赞赏按钮跳动鼠标点击特效复制版权提示彩色标签云及右栏数字自定义右键响应时间和访客总数全站字数统计版权提示时间流逝添加心知天气总结 前言 ha…...

(9)python开发经验

文章目录 1 os.path.join()拼接路径2 条件变量3 添加临时环境变量 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt开发 &#x1f448;&#x1f449;python开发 &#x1f448; 1 os.path.join()拼接路径 os.path.join() 是 Python 中处理文件路径拼接的核心函…...

【C++详解】string各种接口如何使用保姆级攻略

文章目录 一、string介绍二、string使用构造函数析构函数赋值运算符重载string的遍历修改方法1、下标[]2、迭代器3、范围for 迭代器使用详解const迭代器反向迭代器&#xff08;reverse) Capacity(容量相关)size/lengthmax_sizecapacityclear/emptyshrink_to_fit(缩容)reserve(扩…...