码迷,mamicode.com
首页 > 编程语言 > 详细

leetcode-209 长度最小的数组

时间:2019-07-21 01:13:20      阅读:109      评论:0      收藏:0      [点我收藏+]

标签:code   http   return   sel   inf   ret   lock   pre   res   

leetcode-209 长度最小的数组

题目描述:

给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组。如果不存在符合条件的连续子数组,返回 0。
参考:负雪明烛

class Solution(object):
    def minSubArrayLen(self, s, nums):
        """
        :type s: int
        :type nums: List[int]
        :rtype: int
        """
        res = float("inf")
        l,r = 0,0
        N = len(nums)
        sumc = 0
        # 两个while的很有趣,只使用n的复杂度完成这个问题,感觉还是要把思维理清,要分步骤,不要一团浆糊
        while r < N:
            sumc += nums[r]
            while sumc >= s:
                res = min(res,r-l+1)
                sumc -= nums[l]
                l += 1
            r += 1
        return res if res<float("inf") else 0

leetcode-209 长度最小的数组

标签:code   http   return   sel   inf   ret   lock   pre   res   

原文地址:https://www.cnblogs.com/curtisxiao/p/11219748.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!