领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD
Markdown版本笔记 | 我的GitHub首页 | 我的博客 | 我的微信 | 我的邮箱 |
---|---|---|---|---|
MyAndroidBlogs | baiqiantao | baiqiantao | bqt20094 | baiqiantao@sina.com |
领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD
目录
长度最小的子数组 Minimum Size Subarray Sum -209
问题
给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s
的长度最小的连续子数组
。如果不存在符合条件的连续子数组,返回 0
。
示例:
输入: s = 7, nums = [2,3,1,2,4,5]
输出: 2
解释: 子数组 [4,5] 是该条件下的长度最小的连续子数组。
进阶:
如果你已经完成了 O(n)
时间复杂度的解法, 请尝试 O(n log n)
时间复杂度的解法。
暴力法
class Solution {
public int minSubArrayLen(int s, int[] nums) {
int len = Integer.MAX_VALUE, tem;
for (int i = 0; i < nums.length; i++) {
tem = 0;
for (int j = i; j < nums.length; j++) {
tem += nums[j];
if (tem >= s) {
len = Math.min(len, j - i + 1);
break;
}
}
}
return len == Integer.MAX_VALUE ? 0 : len;
}
}
时间复杂度:O(n^2)
空间复杂度:O(1)
暴力法稍加改进(然并卵)
class Solution {
public int minSubArrayLen(int s, int[] nums) {
int len = Integer.MAX_VALUE, tem;
for (int i = 0; i < nums.length; i++) {
tem = 0;
for (int j = i; j < nums.length && j < i + len - 1; j++) {
tem += nums[j];
if (tem >= s) {
len = j - i + 1;
break;
}
}
}
return len == Integer.MAX_VALUE ? 0 : len;
}
}
时间复杂度:O(n^2)
空间复杂度:O(1)
双指针法(推荐)
我们需要定义两个指针left和right,分别记录子数组的左右的边界位置,然后我们让right向右移,直到子数组和大于等于给定值或者right达到数组末尾,此时我们更新最短距离,并且将left向右移一位,然后再sum中减去移去的值,然后重复上面的步骤,直到right到达末尾,且left到达临界位置,即要么到达边界,要么再往右移动,和就会小于给定值
class Solution {
public int minSubArrayLen(int s, int[] nums) {
int len = Integer.MAX_VALUE, left = 0, sum = 0;
for (int right = 0; right < nums.length; right++) {
sum += nums[right]; //左指针不动,右指针一直向右移动
while (sum >= s) {
len = Math.min(len, right - left + 1); //当满足条件时先记录一下当前需要的长度
sum -= nums[left++]; //然后左指针向右移动(移动过程中如果满足条件则长度-1),直到不满足条件(继续移动右指针)
}
}
return len == Integer.MAX_VALUE ? 0 : len;
}
}
时间复杂度:O(n)
空间复杂度:O(1)
二分查找法(不懂)
思路是,我们建立一个比原数组长一位的sums数组,其中sums[i]
表示nums数组中[0, i - 1]
的和,然后我们对于sums中每一个值sums[i]
,用二分查找法找到子数组的右边界位置,使该子数组之和大于sums[i] + s
,然后我们更新最短长度的距离即可。
class Solution {
public int minSubArrayLen(int s, int[] nums) {
int len = nums.length, res = len + 1;
int[] sums = new int[len + 1];
for(int i = 1; i<len+1; i++){
sums[i] = sums[i-1] + nums[i-1];
}
for(int i = 0; i<len+1; i++){
int right = searchRight(i+1, len, sums[i]+s, sums);
if(right == len + 1) break;
if(res > right - i) res = right - i;
}
return res == len + 1?0:res;
}
private int searchRight(int left, int right, int key, int sums[]){
while(left <= right){
int mid = (left + right)/2;
if(sums[mid] >= key){
right = mid - 1;
}else{
left = mid + 1;
}
}
return left;
}
}
2016-12-28
2018-12-16
领扣-209 长度最小的子数组 Minimum Size Subarray Sum MD的更多相关文章
- LeetCode 209:最小长度的子数组 Minimum Size Subarray Sum
公众号: 爱写bug(ID:icodebugs) 作者:爱写bug 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子 ...
- [Swift]LeetCode209. 长度最小的子数组 | Minimum Size Subarray Sum
Given an array of n positive integers and a positive integer s, find the minimal length of a contigu ...
- 【LeetCode】209. 长度最小的子数组
209. 长度最小的子数组 知识点:数组:前缀和:二分法:双指针:滑动窗口 题目描述 给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其和 ≥ target 的长度最小 ...
- Java实现 LeetCode 209 长度最小的子数组
209. 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = ...
- Leetcode 209.长度最小的子数组 By Python
给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = 7, nums = [2, ...
- LeetCode 209. 长度最小的子数组(Minimum Size Subarray Sum)
题目描述 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 0. 示例: 输入: s = 7, nums ...
- 和大于S的最小子数组 · Minimum Size Subarray Sum
[抄题]: 给定一个由 n 个正整数组成的数组和一个正整数 s ,请找出该数组中满足其和 ≥ s 的最小长度子数组.如果无解,则返回 -1. 给定数组 [2,3,1,2,4,3] 和 s = 7, 子 ...
- 代码随想录第二天| 977.有序数组的平方 ,209.长度最小的子数组 ,59.螺旋矩阵II
2022/09/22 第二天 第一题 这题我就直接平方后排序了,很无脑但很快乐啊(官方题解是双指针 第二题 滑动窗口的问题,本来我也是直接暴力求解发现在leetCode上超时,看了官方题解,也是第一次 ...
- LeetCode:长度最小的子数组【209】
LeetCode:长度最小的子数组[209] 题目描述 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的连续子数组.如果不存在符合条件的连续子数组,返回 ...
随机推荐
- LoadRunner监控Linux资源
一.LoadRunner监控Linux资源 (一).准备工作 首先,监视Linux一定要有rstatd这个守护进程,有的Linux版本里也有可能是rpc.rstatd这里只是名字不同而已,功能是一样的 ...
- jquery 美化弹出提示 漂亮的Dialog 对话框
三个不同的效果,分别是普通的警告,确认/取消,带一个输入框 本例用了jquery.alertify.js,请到演示页面查看 css文件也请到演示页面查看 JavaScript Code <scr ...
- thinkphp5.0环境变量配置
允许使用环境变量配置,并且优先级别比在配置文件中要高,因为在读取配置参数的时候,首先会判断环境变量中是否存在该配置. 在开发过程中,可以在应用根目录下面的.env来模拟环境变量配置,.env文件中的配 ...
- Django+Nginx+uwsgi搭建自己的博客(二)
在上一篇博客中,为大家介绍了Django的一些基本概念以及建立了第一个App——Users,并且在数据库中建立了对应的表. 在这篇博客中,将为大家继续介绍数据库模型的定义和相关操作,以及Users A ...
- Git 无法拉取,Unlink of file '.git/objects/pack/pack-***.pack' failed. Should I try again? (y/n)
现象 Git 无法拉取,提示: Unlink of file '.git/objects/pack/pack-***.pack' failed. Should I try again? (y/n) 原 ...
- ActiveMQ 权限(一)
在 ActiveMQ 认证(一) 中,若用户名或密码不正确,不能连接到ActiveMQ.我们可以通过配置文件,确用户是否有消息的读取.写入和管理的权限. 在plugin配置节点下,配置以下信息: &l ...
- 磁盘镜像分析工具Autopsy
磁盘镜像分析工具Autopsy Autopsy是Kali Linux预安装的一款磁盘镜像分析工具.该工具可以对磁盘镜像的卷和文件系统进行分析,支持Unix和Windows系统.Autopsy是一个 ...
- centos7.3挂在移动硬盘(亲测)
一 下载ntfs-3g wget https://tuxera.com/opensource/ntfs-3g_ntfsprogs-2016.2.22.tgz 二 解压并安装 1 检测是否安装gcc r ...
- 安装与配置ironic
安装及配置 由于Ironic的配置很长,下面我们简短的说一下安装和配置过程,具体的安装配置教程参考官方手动配置教程或者使用devstack安装. Ironic需要与Nova.Neutron.Glanc ...
- (转)Ubuntu 16.04 安裝Docker(PS:本文适用amd64位的ubuntu系统)
1.前置安裝,確保你的系統是64位 $ sudo apt-get install \ apt-transport-https \ ca-certificates \ curl \ software-p ...