2831. 找出最长等值子数组 Medium

给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。

如果子数组中所有元素都相等,则认为子数组是一个 等值子数组 。注意,空数组是 等值子数组 。

从 nums 中删除最多 k 个元素后,返回可能的最长等值子数组的长度。

子数组 是数组中一个连续且可能为空的元素序列。

示例 1:

输入:nums = [1,3,2,3,1,3], k = 3
输出:3
解释:最优的方案是删除下标 2 和下标 4 的元素。
删除后,nums 等于 [1, 3, 3, 3] 。
最长等值子数组从 i = 1 开始到 j = 3 结束,长度等于 3 。
可以证明无法创建更长的等值子数组。

示例 2:

输入:nums = [1,1,2,2,1,1], k = 2
输出:4
解释:最优的方案是删除下标 2 和下标 3 的元素。 
删除后,nums 等于 [1, 1, 1, 1] 。 
数组自身就是等值子数组,长度等于 4 。 
可以证明无法创建更长的等值子数组。

提示:

 ·1 <= nums.length <= 105

 ·1 <= nums[i] <= nums.length

 ·0 <= k <= nums.length

题目大意:计算最多删除k个元素的情况下数组中最长等值子数组的长度。

分析:设区间[i,j]中众数的个数为maxCount。

(1)区间[i,j]中的最长等值子数组长度<=区间[i-1,j]中的最长等值子数组长度;

(2)由(1)可知,当区间右端点j确定时,左端点i越小越好。又因为最多只能删除k个元素,因此当j确定时,i的最小值是固定的,即i在最小处时,数组i-1号元素不等于区间[i,j]中的众数,且j-i+1-maxCount==k;

(3)由(2)可知,可利用滑动窗口,不断向右移动窗口右端点j,当j-i+1-maxCount==k+1时,向右移动窗口左端点i,同时在移动滑动窗口过程中维护maxCount的值即可;

(4)设右端点j对应的最小左端点为i,右端点n对应的最小左端点为m,区间[i,j]的众数个数为maxCount1,区间[m,n]的众数个数为maxCount2,由(2)中结论可知j-i+1=k+maxCount1,n-m+1=k+maxCount2。因此当maxCount2>maxCount1时,n-m>j-i,所以maxCount越大,窗口的长度越长;

(5)由于在遍历过程中要获取最大的maxCount,根据(4)中结论,只需维护最大的maxCount即可,当前右端点对应的区间长度也只需保持为出现过的最长区间长度,只有当更大的maxCount出现时,才会扩大区间。因为当前区间的众数个数若无法超越maxCount,即使区间长度可能大于其本应设置的长度,但由于区间长度并未超越出现过的最长区间的长度,对于maxCount的值并不会产生影响。

class Solution {
public:int longestEqualSubarray(vector<int>& nums, int k) {int N=nums.size(),size=0,maxCount=0;unordered_map<int,int> map;for(int l=-1,r=0;r<N;++r){maxCount=max(maxCount,++map[nums[r]]);//根据maxCount的大小更新区间范围if(++size-maxCount==k+1){--size;--map[nums[++l]];}}return maxCount;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/13904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaSwing仓库商品管理系统(文档+视频+源码)

摘要 Java swing实现的一款简单的仓库商品管理系统&#xff0c;数据库采用的是mysql&#xff0c;本系统实现了两个角色层面的功能&#xff0c;管理员可以管理用户、仓库、商品信息等。普通用户登录后可以查看商品、仓库信息及个人信息。 系统实现 登录界面&#xff1a; 我们…

分布式音乐播放器适配了Stage模型

OpenAtom OpenHarmony&#xff08;以下简称“OpenHarmony”&#xff09;应用开发自API 8及其更早版本一直使用的是FA模型进行开发。FA模型是Feature Ability的缩写&#xff0c;它和PA&#xff08;Particle Ability&#xff09;两种类型是过往长期推广的术语&#xff0c;深入人心…

stm32常用编写C语言基础知识,条件编译,结构体等

位操作 宏定义#define 带参数的宏定义 条件编译 下面是头文件中常见的编译语句&#xff0c;其中_LED_H可以认为是一个编译段的名字。 下面代码表示满足某个条件&#xff0c;进行包含头文件的编译&#xff0c;SYSTEM_SUPPORT_OS可能是条件&#xff0c;当非0时&#xff0c;可以…

js代码控制bootstrap的模态框(modal)

在Bootstrap 5中&#xff0c;模态框&#xff08;Modal&#xff09;是一个自定义的HTML元素&#xff0c;可以用于创建对话框。通过导入Bootstrap的JavaScript模块&#xff0c;可以使用其API来控制模态框的显示和隐藏。以下是一个简单的示例说明如何使用Bootstrap 5中的模态框。 …

.NET8 动态添加定时任务(CRON Expression, Whatever)

需要使用 Quartz .NET <PackageReference Include"Quartz.AspNetCore"/>建立 Global JobKey public static class GlobalJobKey {public static JobKey CustomizedKey > new JobKey("xxx scheduled", "group1"); }建立 Job public clas…

前端发起请求的5种方式

好的&#xff0c;以下是针对上述五种方式的代码实现&#xff0c;每种方式都将使用给定的请求地址、请求方法&#xff08;POST&#xff09;、请求体和请求头来发送请求&#xff1a; XMLHttpRequest (XHR): var xhr new XMLHttpRequest(); var url "https://open.bigmod…

xorm和gorm数据库结构体当返回参数

我们在开发golang项目代码的时候&#xff0c;都会用到数据数据库工具&#xff0c;现在主流的就是xorm和gorm&#xff0c;然后我们一般会创建数据库表的结构体表单&#xff0c;如下所示&#xff1a; type Task struct {ID int64 gorm:"column:id;ty…

数据仓库之ClickHouse

ClickHouse是一个用于联机分析处理&#xff08;OLAP&#xff09;的列式数据库管理系统&#xff08;DBMS&#xff09;&#xff0c;特别适用于在线分析处理&#xff08;OLAP&#xff09;场景中的快速数据查询。以下是关于ClickHouse作为数据仓库的一些主要特点和优势&#xff1a;…

C++设计模式|结构型 适配器模式

1.什么是适配器模式&#xff1f; 可以将⼀个类的接⼝转换成客户希望的另⼀个接⼝&#xff0c;主要⽬的是 充当两个不同接⼝之间的桥梁&#xff0c;使得原本接⼝不兼容的类能够⼀起⼯作。 2. 适配器模式的组成 &#xff08;1&#xff09;接口类&#xff0c;给客户端调用&…

vue的异步操作,钩子函数,和Element组件

使用vue进行异步操作 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </…

【NumPy】关于numpy.zeros()函数,看这一篇文章就够了

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

XV4001KD汽车级应用的数字输出陀螺传感器

XV4001KD是一款专为汽车导航系统和远程信息处理而设计的数字输出陀螺传感器。采用SPI/I2C串行接口&#xff0c;具有高精度的16位的角速率输出和11位的温度输出功能&#xff0c;能够准确地测量车辆的运动状态和环境温度&#xff0c;为导航系统和信息处理提供可靠的数据支持。以及…

《二》MP3在线搜索所歌曲的实现

上一期我们大致实现了布局等操作 那么这一期我们来实现如何去搜索歌曲&#xff1a; 首先呢&#xff0c;我们是设计多媒体&#xff0c;要包含多媒体类头文件&#xff0c;还要能在线搜索&#xff0c;那就要包含网络上的头文件&#xff0c;还要实现打开文件操作&#xff0c;处理…

Pytorch DDP分布式细节分享

自动微分和autograde 自动微分 机器学习/深度学习关键部分之一&#xff1a;反向传播&#xff0c;通过计算微分更新参数值。 自动微分的精髓在于它发现了微分计算的本质&#xff1a;微分计算就是一系列有限的可微算子的组合。 自动微分以链式法则为基础&#xff0c;依据运算逻…

kubeadm部署k8s v1.28

一、主机准备 主机硬件配置说明 作用IP地址操作系统配置k8s-master01192.168.136.55openEuler-22.03-LTS-SP12颗CPU 4G内存 50G硬盘k8s-node01192.168.136.56openEuler-22.03-LTS-SP12颗CPU 4G内存 50G硬盘k8s-node02192.168.136.57openEuler-22.03-LTS-SP12颗CPU 4G内存 50G…

安全生产月答题pk小程序怎么做

在当今信息化时代&#xff0c;小程序已成为人们日常生活和工作中不可或缺的一部分。特别是在安全生产领域&#xff0c;通过小程序进行答题PK活动&#xff0c;不仅可以提高员工的安全意识&#xff0c;还能促进团队间的协作与交流。本文将详细介绍如何制作一款安全生产月答题PK小…

C语言实现贪吃蛇游戏

文章目录 前言一、蛇的结构的创建二、游戏测试的逻辑三、初始化游戏四、游戏运行五、游戏结束总结 前言 C语言实现贪吃蛇游戏 一、蛇的结构的创建 先创建一个蛇身的节点在创建蛇的结构&#xff08;包括&#xff1a;指向蛇头的指针&#xff0c;指向食物的指针&#xff0c;游戏…

初识DataX3.0

目前接到任务&#xff0c;让同步表数据。市面很多同步工具不一一尝试了&#xff0c;信赖阿里&#xff0c;所以调研了一下阿里的dataX,一点点来吧&#xff0c;学习为主 环境准备&#xff1a;linux6.8 python自带的2.7 MySQL 5.7.1 1.先下载&#xff1a; wget http://datax-o…

油猴脚本使用cookie一般是某请求返回的setcookie,一般不是js生成的,直接请求拼接

写完hook脚本 删除页面cooike&#xff0c;打开开发者模式&#xff0c;刷新页面 cookie一般是某请求返回的setcookie,一般不是js生成的&#xff0c;直接请求拼接带cookie请求 看网络里的cookie httponly打钩的是服务器返回的&#xff0c;但不一定对&#xff0c;还是要看保存日…

MPLS VPN

不是公司的产品&#xff0c;是运营商对外提供的一种服务 没咋懂&#xff0c;oh my god