leetcode209. 长度最小的子数组 借这个题规范一下双指针写法

举报
兔老大 发表于 2021/04/22 00:51:23 2021/04/22
【摘要】 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组。如果不存在符合条件的连续子数组,返回 0。 示例:  输入: s = 7, nums = [2,3,1,2,4,3] 输出: 2 解释: 子数组 [4,3] 是该条件下的长度最小的连续子数组。 进阶: 如果...

给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组。如果不存在符合条件的连续子数组,返回 0。

示例: 

输入: s = 7, nums = [2,3,1,2,4,3]
输出: 2
解释: 子数组 [4,3] 是该条件下的长度最小的连续子数组。
进阶:

如果你已经完成了O(n) 时间复杂度的解法, 请尝试 O(n log n) 时间复杂度的解法。

思路:双指针

这个题我规范了一下代码怎么写:

这是第一遍:

这是改规范之后:


  
  1. class Solution {
  2. public int minSubArrayLen(int s, int[] nums) {
  3. int len=nums.length;
  4. if(len==0)return 0;
  5. int ans=len+1;
  6. int sum=0;
  7. int begin=0;
  8. int end=0;
  9. while(end<len){
  10. sum+=nums[end++];
  11. while(sum>=s){
  12. if(ans>end-begin)ans=end-begin;
  13. sum-=nums[begin++];
  14. }
  15. }
  16. return ans==len+1?0:ans;
  17. }
  18. }

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/104134751

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。