Leetcode:NO.209 長度最小的子數組 移動窗口

題目

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

示例: 

輸入: s = 7, nums = [2,3,1,2,4,3]
輸出: 2
解釋: 子數組 [4,3] 是該條件下的長度最小的連續子數組。
進階:

如果你已經完成了O(n) 時間複雜度的解法, 請嘗試 O(n log n) 時間複雜度的解法。

鏈接:https://leetcode-cn.com/problems/minimum-size-subarray-sum

解題記錄

  • 通過左右兩個指針計算加和,left<=right,如果加和大於等於s的話那麼更新距離,加和減去left並且left前進以爲
  • 如果加和小於s的話right前進以爲並加上此時right的值,知道right到最後
/**
 * @author ffzs
 * @describe
 * @date 2020/6/28
 */
public class Solution {
    public static int minSubArrayLen(int s, int[] nums) {
        int len = nums.length;
        int left = 0, right = 0;
        if (len == 0) return 0;
        int sum = nums[left];
        int res = len + 1;
        while (true) {
            if (sum >= s) {
                if (left == right) return 1;
                res = Math.min(res, right-left+1);
                sum -= nums[left ++];
            }
            else{
                right ++;
                if (right == len) break;
                sum += nums[right];
            }
        }
        return res==len+1 ? 0:res;
    }

    public static void main(String[] args) {
        int[] nums = {2,3,1,2,4,3};
        System.out.println(minSubArrayLen(7, nums));
    }
}

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章