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;
    }
}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值