題目
給定一個含有 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));
}
}