leetcode刷題209 長度最小的子陣列

2021-10-08 07:20:50 字數 732 閱讀 9577

給定乙個含有 n 個正整數的陣列和乙個正整數 s ,找出該陣列中滿足其和 ≥ s 的長度最小的 連續 子陣列,並返回其長度。如果不存在符合條件的子陣列,返回 0。

示例:輸入:s = 7, nums = [2,3,1,2,4,3]

輸出:2

解釋:子陣列 [4,3] 是該條件下的長度最小的子陣列。

class

solution

:def

minsubarraylen

(self, s:

int, nums: list[

int])-

>

int:

n =len(nums)

if s >

sum(nums)

:return

0 le ,ri =0,

0 res =

len(nums)+1

sum_lr =

0while ri < n:

while sum_lr < s and risum_lr += nums[ri]

ri +=

1while sum_lr >= s and le>=0:

res =

min(res, ri - le)

sum_lr -= nums[le]

le +=

1return res

思路:滑動視窗,雙指標~

衝衝衝~

Leetcode209題長度最小的子陣列

題目 給定乙個含有 n 個正整數的陣列和乙個正整數 s 找出該陣列中滿足其和 s 的長度最小的連續子陣列。如果不存在符合條件的連續子陣列,返回 0。示例輸入 s 7,nums 2,3,1,2,4,3 輸出 2解釋 子陣列 4,3 是該條件下的長度最小的連續子陣列。題解 本題可以採用雙指標法進行求解,...

leetcode 209 長度最小的陣列

題目描述 給定乙個含有 n 個正整數的陣列和乙個正整數 s 找出該陣列中滿足其和 s 的長度最小的連續子陣列。如果不存在符合條件的連續子陣列,返回 0。參考 負雪明燭 class solution object def minsubarraylen self,s,nums type s int ty...

LeetCode 209 長度最小的子陣列

題目鏈結 題目描述 給定乙個含有 n 個正整數的陣列和乙個正整數 s 找出該陣列中滿足其和 s 的長度最小的連續子陣列。如果不存在符合條件的連續子陣列,返回 0。示例輸入 s 7,nums 2,3,1,2,4,3 輸出 2 解釋 子陣列 4,3 是該條件下的長度最小的連續子陣列。解決方法 兩種方法 ...