Leetcode 209 - 长度最小的子数组 - Java版本答案

原题链接:力扣

题目描述:

给定一个含有n个正整数的数组和一个正整数target,找出该数组中满足其和>=target 的长度最小的连续子数组[nums1,nums1+1,numsr-1,numsr],并返回其长度。如果不存在符合条件的子数组,返回0。

示例:

输入:target = 7, nums = [2,3,1,2,4,3]

输出:2

方法:

1、暴力法,两层for循环寻找最短的连续子数组,用例超出时间限制

2、滑动窗口法,right为窗口结束处

Java版本答案:

class Solution {
    public int minSubArrayLen(int target, int[] nums) {
        //暴力法,两层for循环寻找最短的连续子数组
        //用例超出时间限制
        // int result = Integer.MAX_VALUE;
        // int sum = 0;
        // int subLength = 0;
        // for(int i = 0;i < nums.length;i++){
        //     sum = 0;
        //     for(int j = i;j < nums.length;j++){
        //         sum += nums[j];
        //         if(sum >= target){
        //             subLength = j - i + 1;
        //             result = subLength < result ? subLength : result;
        //             break;
        //         }
        //     }
        // }
        // return result == Integer.MAX_VALUE ? 0 : result;

        //滑动窗口法,right为窗口结束处
        int left = 0;
        int sum = 0;
        int result = Integer.MAX_VALUE;
        int subLength = 0;
        for(int right = 0;right < nums.length;right++){
            sum += nums[right];
            while(sum >= target){
                // subLength = right - left + 1;
                // result = subLength < result ? subLength : result;
                // sum -= nums[left];
                // left ++;
                //优化前4行
                result = Math.min(result,right - left + 1);
                sum -= nums[left++];
            }
        }
        return result == Integer.MAX_VALUE ? 0 : result;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小徐甜甜圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值