【Leetcode-209】長度最小的子數組

方法一、遍歷元素,逐項尋找子數組

方法二、雙指針法

i,j開始都指向0;
j開始右移,若s(i,j)的和大於等於target,則減去arr[i],i右移,直至s(i,j)小於target;
j繼續右移,同樣操作,直至最後;

int minSubArrayLen(int s, int *nums, int numsSize) {
    if (numsSize == 0) {
        return 0;
    }
    int ans = INT_MAX;
    int start = 0, end = 0;
    int sum = 0;
    while (end < numsSize) {
        sum += nums[end];
        while (sum >= s) {
            ans = fmin(ans, end - start + 1);
            sum -= nums[start];
            start++;
        }
        end++;
    }
    return ans == INT_MAX ? 0 : ans;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章