leetcode209:长度最小的子数组

题目链接:209. 长度最小的子数组 - 力扣(LeetCode)

复制代码
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int n = nums.size();
        if(n == 0)  return 0;
        int end = 0, start = 0, sum = 0, ans = 0x3f3f3f3f;
        while(end < n)
        {
            sum += nums[end];
            while(sum >= target)
            {
                ans = min(ans, end - start + 1);
                sum -= nums[start];
                start++;
            }
            end++;
        }
        return ans == 0x3f3f3f3f ? 0 : ans;
    }
};

这个题目学会了一个新的知识点,《滑动窗口》简单来说一下这个知识点。

滑动窗口:其实·就是在一个数组上定义两个指针,来给出判断条件,推动指针的移动。

就拿力扣上官方的ppt来演示

以下的12张ppt是来演示这个题目的过程

这个ppt是不断更新ans的值,刚开始要设定ans的值是INT_MAX,实际上0x3f3f3f3f是一样的,我这里解释说一下,为什么是while(sum >= target)而不是if(sum >= target) 因为你end指向后面的时候,这个数大于当前的target了,假设说end只想最后一个数是9,这时候大于target了,要让start++,前面的一个数或者两个数,或者三个数加起来都是小于9的话,那这时候是不是不能用if了,因为if只能判断一次,而while是循环,能让start往前走走走,走到sum <= target为止。

再讲一下,要是最后的结果是必须要用仅且一个if和else的条件的话,我建议还是用三目运算符。

条件 ?条件真结果1 :条件假结果2

相关推荐
LDG_AGI5 分钟前
【推荐系统】深度学习训练框架(九):推荐系统与LLM在Dataset、Tokenizer阶段的异同
人工智能·深度学习·算法·机器学习·推荐算法
爪哇部落算法小助手9 分钟前
每日两题day61
数据结构·c++·算法
Swift社区9 分钟前
LeetCode 439 - 三元表达式解析器
算法·leetcode·ssh
小殊小殊10 分钟前
重磅!DeepSeek发布V3.2系列模型!
论文阅读·人工智能·算法
裤裤兔11 分钟前
利用matlab进行FDR校正的实现方式
数据结构·算法·matlab·多重比较矫正·校正·fdr
野蛮人6号11 分钟前
力扣热题100道之31下一个排列
算法·leetcode·职场和发展
子一!!12 分钟前
哈希桶,元素插入逻辑实现
算法·哈希算法
敲代码的嘎仔12 分钟前
LeetCode面试HOT100——160. 相交链表
java·学习·算法·leetcode·链表·面试·职场和发展
吃着火锅x唱着歌12 分钟前
LeetCode 454.四数相加II
算法·leetcode·职场和发展
敲代码的嘎仔14 分钟前
LeetCode面试HOT100—— 206. 反转链表
java·数据结构·学习·算法·leetcode·链表·面试