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

力扣209:长度最小的子数组

力扣209:长度最小的子数组

  • 题目
  • 思路
  • 代码

题目

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

找出该数组中满足其总和大于等于 target 的长度最小的 子数组 [numsl, numsl+1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。

思路

这道题我们先把条件改一下,我们先找符合条件的子数组不需要要长度最小的,那么我们只需要一个for循环再加一个if判断就可以了,思路就是我们从数组头开始一个一个的加直到总值大于target即可。现在我们再想怎么得到长度最小的子数组,要知道我们的条件是总和大于等于target的子数组所以在我们加上最后一个数满足条件时我们当时子数组的尾就已经定死了,我们只能移动头也就是我们可以减去子数组第一个位置来判断是否还满足条件。每次移动头之前我们都判断一下现在子数组的长度是否是最小的。所以整体的思路就是我们先移动子数组的尾等尾定死了我们就再移动头直到没法满足条件我们再开始移动尾,然后满足条件后再继续移动头。这样来回的移动头尾的位置从而得到长度最小的子数组。
所以我们发现我们的子数组是在不断的移动的也可以说是在滑动的,这也就是滑动窗口的思路。

代码

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int res = INT_MAX;int n = nums.size();if(n == 0){return 0;}//子数组的范围int end = 0;int start = 0;int total = 0;while(end < n){//移动子数组的尾直到满足条件total += nums[end];//移动子数组的头直到不满足条件while(total >= target){//等到total大于target//我们就可以移动子数组的头从而得到最小长度res = min(res,end-start+1);total -= nums[start];start++;}end++;}return res == INT_MAX ? 0 : res;}
};
http://www.dtcms.com/a/306339.html

相关文章:

  • 锁定中科院1区TOP!融合LSTM与Attention做时间序列预测 !
  • Metering Solution for Solar + Storage光伏+储能计量解决方案 UL 2735 Certification功率表能源监测电表
  • 电池自动生产线:科技赋能下的高效制造新范式
  • ‌CASE WHEN THEN ELSE END‌
  • GitHub 趋势日报 (2025年07月29日)
  • 【记录资源】
  • Linux基于nginx及其相关工具查看网站访问记录
  • FreeRTOS 在任务中创建优先级更高的任务会立刻切换任务吗?
  • 基于成像空间转录组技术的肿瘤亚克隆CNV原位推断方法
  • 如何将DICOM文件制作成在线云胶片
  • FPGA(或者数字电路)中组合逻辑和时序逻辑是怎么划分的
  • 2025年ESWA SCI1区TOP,强化学习多目标灰狼算法MOGWO-RL+分布式混合流水车间调度,深度解析+性能实测
  • 多个滑块的信号条的实现
  • 数据与个人信息在刑法中的界定:解析非法获取行为的两罪判定标准
  • C/C++内存管理与初阶模板
  • 力扣热题100-------74.搜索二维矩阵
  • Docker启动容器命令详解
  • VLLM离线推理本地Qwen3_32B大模型
  • Linux的应用层协议——http和https
  • SpringBoot 整合 自定义MongoDB
  • 大坝安全监测站:对大坝的坝体、坝基、两岸边坡及相关设施进行全方位、实时的安全监测
  • 分层解耦(Controller,Service,Dao)
  • RHCA - CL260 | Day03:配置 RHCS 集群
  • 城市内涝淹水体积估算工作流程(QGIS)
  • 开疆智能Mpdbus转Profinet网关连接电磁流量计配置案例
  • 20250730在荣品的PRO-RK3566开发板的Android13下调通敦泰的FT8206触控芯片【I2C的挂载】
  • IBM Watsonx BI:AI赋能的下一代商业智能平台
  • 八股文场景题
  • 企业微信API接口发消息实战:从0到1的技术突破之旅
  • MySQL 读写分离