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

同向双指针

长度最小的子数组

力扣209

#define MIN(a, b) ((b) < (a) ? (b) : (a))
int minSubArrayLen(int target, int* nums, int numsSize)
{int ans = numsSize + 1;int left = 0;int right = 0;int sum = 0;for (right = 0; right < numsSize; right++){sum += nums[right];while (sum - nums[left++] >= target){sum -= nums[left++];}if (sum >= target){ans = MIN(numsSize + 1, right - left + 1);}}return ans <= numsSize ? ans : 0;
}

枚举右下标同时右移左下标

以下是对这段代码的解析:

一、宏定义部分

  1. #define MIN(a, b) ((b) < (a)? (b) : (a))
    • 这是一个宏定义,用于求两个数中的最小值。它接受两个参数ab,然后通过三目运算符? :来判断,如果b小于a,就返回b,否则返回a。这种宏定义在代码中可以方便地用于比较两个值的大小并获取较小值。

二、函数minSubArrayLen部分

  1. 变量初始化
    • int ans = numsSize + 1;:这里初始化ansnumsSize + 1,它将用于记录满足条件的子数组的最小长度。初始化为numsSize + 1是因为实际的最小长度不会超过numsSize,这样初始化方便后续比较更新。
    • int sum = 0;:用于记录当前子数组的元素总和,初始化为0。
    • int left = 0;int right = 0;:这两个变量分别作为滑动窗口(子数组)的左右端点,初始时都指向数组的起始位置。
  2. 外层for循环(枚举子数组右端点)
    • for (right = 0; right < numsSize; right++):这个循环的目的是枚举子数组的右端点。每次循环,right指针都会向右移动一位。
    • 在循环内部,首先执行sum += nums[right];,这是将当前right指针指向的元素加入到子数组的总和sum中。
  3. 内层while循环(缩小子数组长度)
    • while (sum - nums[left] >= target):这个循环的目的是在当前子数组总和大于等于target时,尽量缩小子数组的长度。通过不断地将左端点left向右移动(sum -= nums[left++];),来减去子数组最左边的元素,直到子数组总和小于target为止。
  4. 更新最小长度
    • if (sum >= target):当子数组总和大于等于target时,通过ans = MIN(ans, right - left + 1);来计算当前子数组的长度(right - left + 1),并使用之前定义的MIN宏来获取当前长度和之前记录的最小长度ans中的较小值,从而更新ans
  5. 函数返回值
    • return ans <= numsSize? ans : 0;:最后,函数返回ans。如果ans小于等于numsSize,说明找到了满足条件的子数组,直接返回ans;如果ans大于numsSize,则表示没有找到满足条件的子数组,返回0。
http://www.lryc.cn/news/487711.html

相关文章:

  • 小鹏汽车大数据面试题及参考答案
  • 华为再掀技术革新!超薄膜天线设计路由器首发!
  • CREO TOOLKIT二次开发学习之字符转换
  • vmware虚拟机安装Windows11提示电脑不符合要求?
  • 【金融风控项目-08】:特征构造
  • 计算机网络 (2)计算机网络的类别
  • 10.《滑动窗口篇》---②长度最小的子数组(中等)
  • java的强,软,弱,虚引用介绍以及应用
  • STL-stack栈:P1981 [NOIP2013 普及组] 表达式求值
  • Java使用stream进行分组汇总失效问题
  • VMWare虚拟机安装华为欧拉系统
  • 阿里云轻量应用服务器可以用在哪些场景呢
  • OrangePi 5plus yolov5 部署全过程
  • Rust中::和.的区别
  • 集群聊天服务器(7)数据模块
  • VS Code 更改背景颜色
  • OpenAI 助力数据分析中的模式识别与趋势预测
  • IDM扩展添加到Edge浏览器
  • 【SpringBoot】26 实体映射工具(MapStruct)
  • 分层架构 IM 系统之架构演进
  • 基于YOLOv8深度学习的医学影像阿尔兹海默症检测诊断系统研究与实现(PyQt5界面+数据集+训练代码)
  • 【支持向量机(SVM)】:相关概念及API使用
  • Android kotlin之配置kapt编译器插件
  • 时序数据库TDEngine
  • jd-easyflow中inclusive的用法
  • sqlmap图形化安装使用(附文件)
  • 从二维到一维:动态规划矩阵问题的优化之道
  • 计算机视觉(CV):让机器看懂世界
  • 记录下,用油猴Tampermonkey监听所有请求,绕过seesion
  • 服务器产品