【C++】滑动窗口:最大连续1的个数

embedded/2024/9/22 11:04:32/

1.题目

2.算法思路

其实在做这道题的时候并不需要真的把0翻转成1,只需要找到最长的子数组且该子数组中0的个数不大于K,就可以了!

当然我们首先想到的是暴力穷举法:

找到所有符合题意的子数组,跳出最长的那个就可以了。需要嵌套的两层循环,时间复杂度是O(N^2),对于一个在Leetcode上中等难度的题目来说大概率会运行超时,所以我们需要对暴力穷举法进行优化。

那么我们需要同向的双指针left和right来作为子数组的两个端点,用计数器size统计0的个数,用len来记录最大子数组的长度。

当size>K时->left++,这时right不用再回来,因为right回来后它还是会在原来的位置停下来(根据零的个数),所以我们需要不停的往右移动left,知道它越过一个0后停止。

上图是滑动窗口的具体解法步骤。

总结:

当一个题目是对一个区间进行判断,一般问最大最小等问题时往往用到滑动窗口。

再说一下:滑动窗口就是同向的双指针算法。

3.提交结果与代码实现

class Solution {
public:int longestOnes(vector<int>& nums, int k) {int size=0,len=0;for(int left=-1,right=0;right<nums.size();right++){if(nums[right]==0) size++;//进窗口if(size<=k) len=max(len,right-left);//判断和更新结果while(size>k)if(nums[++left]==0) size--;//出窗口}return len;}
};

时间复杂度:O(N)。空间复杂度:O(1)。


http://www.ppmy.cn/embedded/37957.html

相关文章

RabbitMQ保证消息的可靠性

一、背景 消息丢失&#xff1a;下图是消息从生产者发送到消费者接收的关系图。通过图片可以看出&#xff0c;消息在生产者、MQ、消费者这三个环节都有可能丢失。 1.1 生产者丢失 生产者发送消息时连接MQ失败生产者发送消息到达MQ后未找到Exchange生产者发送消息到达MQ的Exc…

小麦穗检测数据集VOC+YOLO格式6508张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;6508 标注数量(xml文件个数)&#xff1a;6508 标注数量(txt文件个数)&#xff1a;6508 标注…

点云成图原理

点成图&#xff08;Point Cloud&#xff09;是指由一组离散的点构成的图形&#xff0c;它们在空间中没有任何连接关系。点成图通常是由激光雷达、相机或其他传感器获取的三维数据&#xff0c;用于表示现实世界中的物体或场景。 三角成图&#xff08;Triangulation&#xff09;…

Android 网络请求 实现

Android 网络请求 实现 一、背景 在Android开发中,网络请求是一个非常常见的需求。应用程序可能需要与远程服务器通信来获取数据、上传文件、验证用户身份等等。背景下,Android应用通常会面临以下几个主要情况和挑战: ①数据交互: 许多应用程序需要从服务器获取数据,例…

《Fundamentals of Power Electronics》——正则电路模型

所有PWM CCM dc-dc转换器执行类似的基本功能。第一&#xff0c;它们转换电压和电流水平&#xff0c;理想状态下效率为100%。第二&#xff0c;它们包含波形的低通滤波功能。虽然有必要去除高频开关纹波&#xff0c;但这种滤波也影响低频电压和电流的变化。第三&#xff0c;转换器…

浙大×移动云,携手点亮AI新时代

近年来&#xff0c;中国移动依托强大的算网资源优势&#xff0c;围绕大模型训练、推理和应用三大场景&#xff0c;打造了一站式智算产品体系。该体系旨在为客户提供覆盖资源、平台、应用的AI全链路服务。目前&#xff0c;一站式智算产品体系已在浙江大学智算中心和许昌中原智算…

西红柿叶病害检测(yolov8模型,从图像、视频和摄像头三种路径识别检测,包含登陆页面、注册页面和检测页面)

1.基于最新的YOLOv8训练的西红柿病害检测模型&#xff0c;和基于PyQt5制作的可视西红柿病害系统&#xff0c;包含登陆页面、注册页面和检测页面&#xff0c;该系统可自动检Bacterial Spot, Early_Blight, Healthy, Late_blight, Leaf Mold, Target_Spot, black spot&#xff0c…

Java反射机制与动态代理解析与应用

Java反射机制与动态代理是Java语言中强大的特性和功能。它们可以使程序在运行时动态地获取和操作类的信息&#xff0c;甚至可以在运行时生成和修改类的代码。本文将对Java反射机制和动态代理进行解析&#xff0c;并探讨它们在实际项目中的应用。 一、Java反射机制 Java反射机…