记力扣2009:使数组连续的最少操作数 练习理解

给你一个整数数组 nums 。每一次操作中,你可以将 nums 中 任意 一个元素替换成 任意 整数。

如果 nums 满足以下条件,那么它是 连续的 :

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

比方说,nums = [4, 2, 5, 3] 是 连续的 ,但是 nums = [1, 2, 3, 5, 6] 不是连续的 。

请你返回使 nums 连续 的 最少 操作次数。

思路:

考虑到正面做需要考虑到:需要替换多少元素不如去想能存在一组最长的数组剩余的即为最小去除数

想到正难则反:直接去找最多可以使哪些元素连续,反面就是最小操作次数在这个流程中,最重要的是题目中最大值减最小值的差为n-1意思是数组全是连续且间隔为1,这个条件读懂后面就只需要滑窗,只需要确保区间长度为n,等价于左端点nums[left]在范围内

复制代码
class Solution:
    def minOperations(self,nums:List[int])->int:
        ans=left=0
        n=len(nums)
        nums=sorted(set(nums))
        for i,char in enumerate(nums):
            while nums[left]<char-n+1:
                left+=1
            ans=max(ans,i-left+1)
        return n-ans

难点:

1.重复数据不影响最小操作数

2.读懂题目隐含条件是连续间隔为1的数组

3.读懂区间为n长度的数组

4.理解nums[left]为最长区间的左端点

5.数组内最大容纳量即为连续数组最小操作次数

相关推荐
骇城迷影5 小时前
Makemore 核心面试题大汇总
人工智能·pytorch·python·深度学习·线性回归
历程里程碑5 小时前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
长安牧笛5 小时前
反传统学习APP,摒弃固定课程顺序,根据用户做题正确性,学习速度,动态调整课程难度,比如某知识点学不会,自动推荐基础讲解和练习题,学习后再进阶,不搞一刀切。
python·编程语言
Sheep Shaun5 小时前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制
Pluchon5 小时前
硅基计划4.0 简单模拟实现AVL树&红黑树
java·数据结构·算法
生锈的键盘5 小时前
推荐算法实践:交叉特征的理解
算法
码界筑梦坊5 小时前
330-基于Python的社交媒体舆情监控系统
python·mysql·信息可视化·数据分析·django·毕业设计·echarts
森焱森5 小时前
详解 Spring Boot、Flask、Nginx、Redis、MySQL 的关系与协作
spring boot·redis·python·nginx·flask
小龙报5 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机