原文:长度最小的子数组
目录
学习笔记,侵删!
1、题目-209.长度最小的子数组
给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组,并返回其长度。如果不存在符合条件的子数组,返回 0。
示例:
输入:s = 7, nums = [2,3,1,2,4,3] 输出:2 解释:子数组 [4,3] 是该条件下的长度最小的子数组。
2、题解
数组操作中一个重要的方法:滑动窗口。
所谓滑动窗口,就是不断的调节子序列的起始位置和终止位置,从而得出我们要想的结果。
class Solution {
// 滑动窗口
public int minSubArrayLen(int s, int[] nums) {
int left = 0;
int sum = 0;
int result = Integer.MAX_VALUE; // Integer.MAX_VALUE代表int的最大值
for (int right = 0; right < nums.length; right++) {
sum += nums[right];
while (sum >= s) {
result = Math.min(result, right - left + 1); // 保留最小长度
sum -= nums[left++]; // 总和减去最左端数值
}
}
return result == Integer.MAX_VALUE ? 0 : result;
// 如果result == Integer.MAX_VALUE说明所有数之和都小于s,此时返回0
}
}
遗忘知识点:Integer.MAX_VALUE代表int的最大值