LeetCode-724. 尋找數組的中心索引

這是我做過的一個題,我把它分享給你們:

這是原文鏈接:https://leetcode-cn.com/problems/minimum-size-subarray-sum/

如果感覺我做的還行的話,記得點贊。

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

示例: 

輸入: s = 7, nums = [2,3,1,2,4,3]
輸出: 2
解釋: 子數組 [4,3] 是該條件下的長度最小的連續子數組。
進階:如果你已經完成了O(n) 時間複雜度的解法, 請嘗試 O(n log n) 時間複雜度的解法。

解題思路:

這個題我就用了滑窗法解這個題,什麼是滑窗法呢?

滑窗法就是想現在的窗戶一樣,整個一部分移動,這就定兩個指針,一個指針指前面,另一個指針指向後面,下一次先把前面的指針向後挪,再把後面的指針直到他對應的位置,又好像是蟲子移動一樣。

具體步驟:

1.先定義兩指針,和要得出的數

2.隨着指針移動判斷他的大小是否大於或等於s

3.比較所有得出的數,把最短的輸出出來。

這道題就解決完成了,下面是我的網頁的代碼,主函數我就不寫了,要驗證的話自己編個主函數驗證下:

class Solution {
    public int minSubArrayLen(int s, int[] nums) {
        int len = 0;
        int i = 0;
        int sum = 0;
        for(int j = 0;j < nums.length;j++){
            sum += nums[j];
            while(sum >= s){
                len = len == 0?(j-i+1):Math.min(len,j-i+1);
                sum -= nums[i]; 
                i++;
            }
        }
        return len;
    }
}

我今天的分享就到這裏,謝謝觀看。

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