长度最小的子数组
创始人
2024-05-15 06:05:20
0

力扣题目

  1. 长度最小的子数组
    给定一个含有 n 个正整数的数组和一个正整数 target 。

找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。

示例 1:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。
示例 2:

输入:target = 4, nums = [1,4,4]
输出:1
示例 3:

输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

提示:

1 <= target <= 109
1 <= nums.length <= 105
1 <= nums[i] <= 105

进阶:

如果你已经实现 O(n) 时间复杂度的解法, 请尝试设计一个 O(n log(n)) 时间复杂度的解法。
通过次数471,456提交次数993,416

我只会O(n^2)的算法哈哈哈哈,哎呀赶紧去学滑动窗口去~,我发现前缀和还挺实用。

暴力代码:前缀和数组

class Solution {
public:int minSubArrayLen(int target, vector& nums) {/** 滑动窗口在算法基础课讲过,但是不会啦,那当时没学透,再学即可* 暴力做法:前缀和~*/vector prefix_sum(nums.size(), 0);prefix_sum[0] = nums[0];// 计算前缀和for (int i = 1; i < nums.size(); i ++ ) prefix_sum[i] = prefix_sum[i - 1] + nums[i];// for (int i = 0; i < nums.size(); i ++ )//     cout << "前缀和为:" << prefix_sum[i] << " ";// 枚举长度1、2、3...n的窗口长度,一次次遍历for (int length = 1; length <= nums.size(); length ++ ) {// cout << "####枚举长度为:" << length << endl;for (int i = length - 1; i < nums.size(); i ++ ) {int l = i + 1 - length - 1, sub_sum;  // 左边界,即要减去的这部分的尾巴if (l == -1) sub_sum = 0;   // 要减去的前部分else sub_sum = prefix_sum[l];// 开始判断当前长度是否存在满足 target的连续序列// cout << "####当前长度下的连续和为:" << prefix_sum[i] - sub_sum << endl;if (prefix_sum[i] - sub_sum >= target) return length;}}return 0;}
};

提交:TLE

长度最小的子数组
提交记录
18 / 20 个通过测试用例
状态:超出时间限制
提交时间:几秒前

AC代码,思路来自卡哥(代码提前看了几眼,那代码估计先入为主,代码也来自卡哥),传送门:代码随想录

class Solution {
public:int minSubArrayLen(int target, vector& nums) {/*** 卡哥讲的滑动窗口思想我目前理解就是双指针咯* 本来暴力解法是:for循环枚举起点+for循环枚举终点* 优化成 1个for循环枚举终点即可* 什么情况后移终点? 当区间和不够,那起点呢?区间和太大。*/int minLength = 1e6;    // 题目给定最长就1e5int start_index = 0;long long sum = 0;  // 最大为1e10for (int end_index = 0; end_index < nums.size(); end_index ++ ) {sum += nums[end_index]; // 终点后移一位,区间和就加上一个数while (sum >= target) {minLength = min(minLength, end_index - start_index + 1);  // 更新最短长度// cout << minLength << " 起点,终点为:[" << start_index << "," << end_index << "]" << endl;// 不用再后移终点了,开始后移起点,缩小区间sum -= nums[start_index];   // 减少起点那个数,接下去再判断一次是不是大于target,是则继续缩小start_index ++ ;    // @@@这里格外注意,先减sum,再移动,不然减错数}// 不够,则后移终点,进行end_index ++ }if (minLength == 1e6) minLength = 0;return minLength;   // 如果是无解,那就是返回0,OK的}
};

相关内容

热门资讯

安卓系统写脚本软件下载,基于安... 你有没有想过,你的安卓手机或者平板电脑,除了用来刷剧、玩游戏,还能变成一个强大的工作助手呢?没错,就...
安卓系统有哪些机型好,探索顶级... 你有没有想过,安卓系统里的手机型号那么多,哪一款才是最适合你的呢?别急,今天我就来给你好好盘点看看安...
安卓系统之间如何互传,安卓设备... 你是不是也和我一样,手机里存了那么多好东西,却苦于不能和好友分享呢?别急,今天就来教你怎么用安卓系统...
安卓系统启动修改工具,安卓系统... 你有没有想过,你的安卓手机启动速度竟然可以像火箭一样快?没错,这就是今天我要跟你分享的神秘工具——安...
安卓系统版本号历史,从初生到繁... 你有没有发现,每次打开手机,那系统版本号总是一闪而过,好像在悄悄告诉你:“我可是有故事的哦!”今天,...
小米改安卓系统软件,安卓系统软... 你知道吗?最近小米手机界可是掀起了一阵小小的风波呢!那就是小米对安卓系统软件的一次大改版。这可不是什...
安卓系统控制流量app,安卓系... 你有没有发现,手机里的流量就像小河里的水,不知不觉就流光了?别急,今天就来给你揭秘一款神奇的安卓系统...
hl2240安卓系统,功能解析... 你有没有发现,最近你的手机系统更新换代的速度简直就像坐上了火箭呢?今天,就让我带你来一探究竟,看看这...
iqoo刷原生安卓系统,还原纯... 最近手机圈里可是热闹非凡呢!一款名为iqoo的新品手机,凭借其强大的性能和独特的刷机功能,吸引了无数...
安卓系统我的读书入口,我的读书... 亲爱的手机控们,你是否也有这样的体验:每天手机不离手,却总是找不到心仪的读书应用?别急,今天我要给你...
搭载安卓9系统的手机,新一代智... 你有没有发现,最近市面上新出的手机,好像都开始搭载安卓9系统了呢?这可真是让人眼前一亮啊!今天,就让...
电脑模拟安卓系统win7系统,... 你有没有想过,如果电脑也能像手机一样,随时随地都能玩各种游戏、看视频呢?想象你坐在电脑前,屏幕上突然...
华为系统如何退回安卓,轻松实现... 你有没有想过,手机系统就像是我们生活中的衣服,有时候穿久了,就想换一件新的。比如,你之前用了华为的系...
安卓系统定制防沉迷手机,安卓手... 你有没有发现,现在的手机越来越智能,但随之而来的是沉迷于手机的问题也越来越严重,尤其是对青少年来说。...
安卓系统手机顶部符号,功能解析... 你有没有注意到,每次拿起安卓系统手机,顶部那一排小小的符号总是默默守护着你的屏幕?它们就像是一群小精...
美团餐饮系统安卓版,尽享美食新... 你有没有发现,最近点外卖的时候,手机上那个美团餐饮系统安卓版真是越来越方便了!今天,就让我带你来好好...
新生活cms安卓系统进货系统,... 你知道吗?最近市面上出现了一个超级酷的新玩意儿——新生活CMS安卓系统进货系统!这可是个让商家们眼睛...
安卓系统ai文章生成,探索安卓... 你知道吗?现在手机界的风云变幻,安卓系统可是当之无愧的王者!而且,最近听说安卓系统里还悄悄加入了AI...
推荐安卓车载导航系统,安卓平台... 你有没有想过,开车的时候,如果没有导航系统,那可真是像在茫茫大海中航行,没有指南针的感觉呢?别急,今...
安卓系统的地图怎样下载,下载与... 你有没有发现,现在不管去哪里,手机地图都成了我们的好帮手?尤其是安卓系统的地图,功能强大,用起来超级...