这是我做过的一个题,我把它分享给你们:
这是原文链接: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;
}
}
我今天的分享就到这里,谢谢观看。