长度最小的子数组

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

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

示例 1:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。

示例 2:

输入:target = 4, nums = [1,4,4]
输出:1

示例 3:

输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

提示:

  • 1 <= target <= 109
  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 105

进阶:

  • 如果你已经实现 O(n) 时间复杂度的解法, 请尝试设计一个 O(n log(n)) 时间复杂度的解法。

法一:暴力法(会超时)双层for循环遍历每种可能序列

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int len = INT32_MAX;
        for(int i = 0;i < nums.size();i ++){
            int res = 0;
            for(int j = i;j < nums.size();j ++){
                res += nums[j];
                if(res >= target) {
                    int tmpLen = j-i+1;
                    len = len < tmpLen ? len : tmpLen;
                    break;
                }
            }
       }
       return len==INT32_MAX?0:len;
    }
};

法二:滑动窗口

这种题就是经典的滑动窗口,我们把子序列当成一个窗口,就是不断滑动这个窗口,从而找到最短的一个满足题意的解。

那么首先我们需要一个for循环,控制窗口尾部,定义一个k控制窗口首部,那么我们只需要循环,在循环时候让res(保存子序列和)不断增加,直到满足target,此时我们将长度算出来,再把最左边的减去,让k向前进,可以用一个三目运算符,判断是否为最小的长度,是的话就更新len。

最后再判断一下len有没有改变过,没改变过就是没找到过符合题意的,返回0,找到了就返回len即可。

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int res = 0,len = INT32_MAX,k = 0;
        for(int i = 0;i < nums.size();i ++){
            res += nums[i];
            while(res >= target){
                len = len<(i-k+1)?len:(i-k+1);
                res -= nums[k];
                k++;
            }
        }
        return len==INT32_MAX?0:len;
    }
};

相关推荐

  1. 209.长度数组

    2024-01-01 04:12:03       37 阅读
  2. 209. 长度数组

    2024-01-01 04:12:03       48 阅读
  3. 长度数组

    2024-01-01 04:12:03       38 阅读
  4. 长度数组

    2024-01-01 04:12:03       22 阅读
  5. 209. 长度数组

    2024-01-01 04:12:03       7 阅读
  6. 力扣209-长度数组

    2024-01-01 04:12:03       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-01 04:12:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-01 04:12:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-01 04:12:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-01 04:12:03       18 阅读

热门阅读

  1. 数据库查询优化

    2024-01-01 04:12:03       39 阅读
  2. PostgreSQL | 概念 | 什么是OLTP&OLAP?

    2024-01-01 04:12:03       39 阅读
  3. 组合设计模式

    2024-01-01 04:12:03       33 阅读
  4. Ant Design Vue表单组件a-form-item-rest使用

    2024-01-01 04:12:03       39 阅读
  5. 如何将Git的语言设置为中文

    2024-01-01 04:12:03       40 阅读
  6. 腾讯云轻量应用服务器测评,2核4G5M配置3年756元

    2024-01-01 04:12:03       37 阅读
  7. 使用函数的选择法排序

    2024-01-01 04:12:03       38 阅读
  8. python的pandas数据分析处理基础学习

    2024-01-01 04:12:03       38 阅读
  9. MySQL中常用的数据类型

    2024-01-01 04:12:03       42 阅读
  10. Android获取电池充电状态是否为快充

    2024-01-01 04:12:03       37 阅读
  11. python统计学-矩估计法、极大似然估计法?

    2024-01-01 04:12:03       38 阅读
  12. Linux: memory: THP相关的一些链接

    2024-01-01 04:12:03       34 阅读
  13. A. Odd One Out

    2024-01-01 04:12:03       36 阅读