当前位置: 首页 > news >正文

记力扣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=0n=len(nums)nums=sorted(set(nums))for i,char in enumerate(nums):while nums[left]<char-n+1:left+=1ans=max(ans,i-left+1)return n-ans

难点:

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

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

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

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

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

http://www.dtcms.com/a/479835.html

相关文章:

  • 怎样健建设一个有利于优化的网站wordpress 萌化主题
  • 网站建设gong广东省建设监理协会网站 - 首页
  • 网页制作与网站建设填空题青岛vps网站
  • 微信公众号对接网站公司网站备案需要什么材料
  • 网站备案核验号网站建设中数据字典
  • 运动网站建设主题兰州学校网站建设
  • 从SEO到GEO:顺应AI搜索优化趋势
  • word超链接网站怎样做家具在线设计平台
  • 【java】mysql
  • 书店手机网站模板个人网站怎么备案可以做哪些
  • 网站大学报名官网入口世界500强企业排名表
  • 查企业信息的国家网站wordpress多城市seo
  • 反转链表及其应用(力扣2130)
  • 沈阳教做网站能挣钱的平台 正规的
  • 合肥企业网站建设公司提供网站建设商家
  • 西安建设学院网站首页wordpress网站设置关键词
  • Java学习之旅第三季-2:异常处理机制之抛出异常
  • 天津市南开区网站开发有限公司小微企业所得税优惠政策
  • 建站之星app公司网站做论坛
  • 做食品那些网站好磁力猫torrentkitty官网
  • 苏州网站建设推广贵阳网络营销推广专家
  • 深圳网站优化页面好看的个人博客主页
  • 第四届声学,流体力学与工程国际学术会议(AFME 2025)
  • 成都广告公司网站建设邯郸求职信息网
  • 杂记 14
  • 后训练技术介绍
  • 怎样做百度推广网站wordpress登陆头像
  • 虚拟主机网站建设步骤?wechat官方下载
  • 网站测速南昌网站建设渠道
  • PMP-项目管理-PMBOK第六版_中文版:管理工具