Java每日一题: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;
    }
}

我今天的分享就到这里,谢谢观看。

你可能感兴趣的:(Leetcode习题总结,图论,动态规划,算法,几何学,java)