LeetCode 使数组连续的最少操作数

news2024/11/27 14:34:09

地址:. - 力扣(LeetCode)
难度:困难
题目描述:给你一个整数数组 nums 。每一次操作中,你可以将 nums 中 任意 一个元素替换成 **任意 **整数。
如果 nums 满足以下条件,那么它是 连续的

  • nums 中所有元素都是 互不相同 的。
  • nums 中 最大 元素与 最小 元素的差等于 nums.length - 1 。

比方说,nums = [4, 2, 5, 3] 是 连续的 ,但是 nums = [1, 2, 3, 5, 6] 不是连续的
请你返回使 nums 连续最少 操作次数。

提示:

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

题解过程

条件1:互不相同,

  • 所以得把相同的数替换掉,并且替换的数不能是数组中存在的数

条件2:最大的元素与最小的元素差 === nums.length(n) - 1

  • 如何确定最大值最小值?
  • 假设最小值为 left最大值 ,那么最大值 right = left+n−1。

问:假设最大最小值确定,那么相同需要替换的数字需要替换成什么?替换的数字可能因为存在数组中又导致重复吗?

答:这种情况是肯定不会存在的,因为 最大值-最小值 === n - 1
也就是说
最大值和最小值直接就差值了n-1
,假设数组紧密排列,两项之间只差值1,得到的数组会是[1,2,3……n],刚好满足最大值 - 最小值 === n-1

反向考虑,假设最后连续的数组的最小值为 left,则最大值 right=left+n−1。
原数组 nums 中,如果有位于 [left,right]中的,如果只出现一次,我们可以对其进行保留;
多次出现时,我们则需要对其进行操作;
不在这个区间的数字,我们也需要对其进行操作,将它们变成其他数字来对这个区间进行补足。
因此,我们需要统计原数组 nums中,位于区间 [left,right]内不同的数字个数 k,而 n−k就是我们需要进行的操作数。

接下来就是需要确定 left,我们可以将原数组 nums所有不同的数字作为 left的候选值,分别计算出 n−k,然后求出最小值。

这样的话,我们可以先将原数组进行去重后排序,然后利用滑动窗口。
滑动窗口左端点的值作为 left,然后向右扩展右端点,窗口的长度即为 k,求出所有可能性下最小的 n−k即可。

例子:[4,2,2,5,3]

例子:[1,10,100,1000]

/**
 * @param {number[]} nums
 * @return {number}
 */
var minOperations = function(nums) {
     const n = nums.length;
     // 去重
     const sortedUniqueNums = [...new Set(nums)];
     // 排序
     sortedUniqueNums.sort((a, b) => a - b);

    let res = n;
    let j = 0;
    for (let i = 0; i < sortedUniqueNums.length; i++) {
        const left = sortedUniqueNums[i]; // 最小值
        const right = left + n - 1; // 最大值
        
        while (j < sortedUniqueNums.length && sortedUniqueNums[j] <= right) {
            // 因为排序过 所以后面的都是不符合要求的 
            //为什么去重不影响结果? 因为n是没去重的结果,减去的是符合要求的数,所以最终结果是对的
            // (i-1)是小于left的值  所以符合要求的结果是j-(i-1) = j-i+1
          res = Math.min(res, n - (j - i + 1));
            j++;
        }
    }
    return res;


};

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

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

相关文章

竞赛 协同过滤电影推荐系统

文章目录 1 简介1 设计概要2 课题背景和目的3 协同过滤算法原理3.1 基于用户的协同过滤推荐算法实现原理3.1.1 步骤13.1.2 步骤23.1.3 步骤33.1.4 步骤4 4 系统实现4.1 开发环境4.2 系统功能描述4.3 系统数据流程4.3.1 用户端数据流程4.3.2 管理员端数据流程 4.4 系统功能设计 …

YOLOv8的多分类模型如何计算准确率(Accuracy)、精确率(Precision)、召回率(recall)和F1-Score模型评估参数

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

算法刷题Day27 | 39. 组合总和、40.组合总和II、131.分割回文串

目录 0 引言1 组合总和1.1 我的解题 2 组合总和II2.1 解题 3 分割回文串3.1 切割3.2 总结&#xff1a;分割和组合的区别 &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;算法专栏&#x1f4a5; 标题&#xff1a;算法刷题Day27 | 39. 组合总和、40.…

【Entity Framework】EF配置文件设置详解

【Entity Framework】EF配置文件设置详解 文章目录 【Entity Framework】EF配置文件设置详解一、概述二、实体框架配置部分三、连接字符串四、EF数据库提供程序五、EF侦听器六、将数据库操作记录到文件中七、Code First默认连接工厂八、数据库初始值设定项 一、概述 EF实体框架…

Taro打包生成不同目录

使用taro init创建taro项目时&#xff0c;taro默认打包目录是&#xff1a; /config/index.js outputRoot:dist默认的目录&#xff0c;编译不同平台代码时就会覆盖掉&#xff0c;为了达到多端同步调试的目的&#xff0c;这时需要修改默认生成目录了&#xff0c;通过查看官方文…

Redis 群集

目录 一、集群的三种模式 1.1 Redis 主从复制 主从复制的作用&#xff1a; 主从复制流程&#xff1a; 主从复制的过程/原理 搭建Redis 主从复制 1.2 Redis 哨兵模式 哨兵模式原理: 哨兵模式的作用&#xff1a; 哨兵模式的结构 故障转移机制&#xff1a; 搭建Redis …

[尚硅谷 flink] 基于时间的合流——双流联结(Join)

文章目录 8.1 窗口联结&#xff08;Window Join&#xff09;8.2 **间隔联结&#xff08;Interval Join&#xff09;** 8.1 窗口联结&#xff08;Window Join&#xff09; Flink为基于一段时间的双流合并专门提供了一个窗口联结算子&#xff0c;可以定义时间窗口&#xff0c;并…

虚拟主机WordPress网站安装教程

一般的企业官网&#xff0c;简站WordPress小编都推荐使用虚拟主机&#xff0c;用虚拟主机搭建一般的WordPress企业官网足够用了。最主要的好处是使用虚拟主机可以省去了主机维护的成本。 下面是以简站WordPress主题在虚拟主机搭建企业官网为例子&#xff0c;写的一个教程&…

无人机详细操作方法:

不同型号的无人机操作方法会有所区别&#xff0c;以云卓无人机为例&#xff0c;为你介绍其操作方法&#xff1a; 1. 打开机臂&#xff0c;安装护架、红外避障头&#xff0c;盖上后盖&#xff1b; 2. 打开飞机和遥控器&#xff0c;将两个油门的外八节进行校准&#xff1b; 3.…

Echarts-实现地图并轮播地图信息

目录 ./map-geojson/jinhua.json./CenterMap.vue./center.vue 使用地图组件效果 ./map-geojson/jinhua.json {"type":"FeatureCollection","features":[{"type":"Feature","properties":{"adcode":330…

ZLMediaKit ubantu 下编译

1、获取代码 #国内用户推荐从同步镜像网站gitee下载 git clone --depth 1 https://gitee.com/xia-chu/ZLMediaKit cd ZLMediaKit #千万不要忘记执行这句命令 git submodule update --init二、依赖库 Debian系(包括ubuntu&#xff09;系统下安装依赖的方法&#xff1a; #除了…

什么是 SD NAND?

什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。 什么是 CS 创世 SD NAND 呢&#xff1f;很多的朋友一直想知道这个问题。今天我们雷龙也精心准备了 SD NAND 的一个介绍。其实很多工程师朋友对 CS 创世 SD NAND 有很多称呼。比如&#xff1a;贴片式 T 卡…

Ethernet 汇总

Ethernet系统 硬件最小系统 CPU:可以是复杂的芯片,也可以是小的单片机DMA:用于减轻CPU负担,搬运数据系统Memory<->FIFOMAC:可以集成在芯片里面,用于CPU和PHY之间的通信MII:接口用于MAC和PHY的通信,包括控制MDIO和数据DataPHY:模拟器件,最底层,数据收发源头软件…

AI智慧医疗:探索机器学习在医疗保健中的应用与进展

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

TEMU平台重要合规内容!关于 RSL Report 铅镉/ RSL Phthalate邻苯

TEMU平台重要合规内容&#xff01;关于 RSL Report 铅镉 / RSL Phthalate 邻苯 的资质认证&#xff01; 欧盟对进口和在欧盟内销售的电子产品都有明确的安全、环保、健康等相关标准要求。 对于可能存在的产品有害物质&#xff0c;欧盟是明确禁止销售的。 因此拼多多跨境平台…

停用net stop mysql 服务名无效。

net stop mysql服务名 错误截图 解决方案 1. 按下 Win R 键&#xff0c;然后输入 services.msc 并按下 Enter 键&#xff0c;打开服务管理器 &#xff0c;查找与 MySQL 相关的服务 重新运行 net stop mysql服务名

python学习笔记——类

1. 类和对象**** 类、类属性、类方法不需要实例化就可以直接访问 实例相关&#xff0c;如实例属性、实例方法必须实例化后才可以访问 1.1. 类、类属性、实例属性、私有属性**** 1.1.1. 定义**** 类就是拥有相同属性和功能对象的集合 动物&#xff1a;猫、狗、鸡 人类&…

PCA算法(Principal Component Analysis)揭秘

经典PCA算法 PCA算法的应用包括降维、有损数据压缩、特征抽取、数据可视化等。目前PCA算法有两个通用定义&#xff0c;能殊途同归&#xff0c;得到相同的结果。一方面&#xff0c;我们可以用正交投影来定义PCA&#xff0c;即将数据投影到更低维的线性子空间&#xff0c;也被称…

【LAMMPS学习】八、基本知识的讨论(1.2)可视化 LAMMPS 快照

8. 基本知识的讨论 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语&#xff0c;以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和…