leetcode 209.长度最小的子数组

题目

209.长度最小的子数组
给定一个含有 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 = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

解题思路

滑动窗口法

实现代码

from typing import List
class Solution:
    def minSubArrayLen(self, target: int, nums: List[int]) -> int:
        # 数组所有元素之和小于target,则子数组的和一定小于target
        if sum(nums) < target:
            return 0
        
        # 定义双指针 
        left = 0
        right = 0
        sums = 0    # 存储连续子数组的和
        res = float('inf')  # 最小连续子数组的长度
        # 满足条件时,尝试缩小子串的长度,寻找最小的连续子数组
        while right < len(nums):
            sums = sums + nums[right]
            while sums >= target:                
                res = min(res, right - left + 1)
                sums = sums - nums[left]
                left += 1
            right += 1
        return res

test = Solution()
# nums = [1,1,1]
# target = 4
nums = [2,3,1,2,4,3]
target = 7
print(test.minSubArrayLen(target, nums))
posted on 2024-04-05 18:07  小鹿BAMBI  阅读(6)  评论(0编辑  收藏  举报