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

2026-05-21:变成目标数组的最少操作次数。用go语言,给定两个长度相同的数组 nums 和 target。 - nums[i] 表示当前位置 i 当前的值。 - target[i] 表示当前位

2026-05-21变成目标数组的最少操作次数。用go语言给你两个长度为 n 的整数数组 nums 和 target。nums[i] 表示当前位置 i 的当前值target[i] 表示你希望当前位置 i 最终变成的期望值。你可以进行任意多次操作可以不做。每次操作你要先选定一个整数 x然后在数组 nums 里找出所有“极大连续区间”这些区间里的每个位置都等于 x且该区间在保持全为 x 的前提下不能再向左或向右扩展也就是已经是该值 x 的最长连续段并且是无法再延伸的那种。对每个这样的区间 [l, r]本次操作会把这个区间内的 nums 全部替换成 target 对应位置的值把 nums[l…r] 直接改成 target[l…r]。你的目标是让最终 nums 完全等于 target问最少需要多少次操作。1 n nums.length target.length 100000。1 nums[i], target[i] 100000。输入 nums [1,2,3], target [2,1,3]。输出 2解释选择 x 1极大段 [0, 0] 被更新 - nums 变为 [2, 2, 3]。选择 x 2极大段 [0, 1] 被更新nums[0] 保持为 2nums[1] 变为 1 - nums 变为 [2, 1, 3]。因此将 nums 转换为 target 需要 2 次操作。题目来自力扣3810。一、分步骤详细推演过程初始状态nums[1, 2, 3]target[2, 1, 3]已操作次数0第一步执行第 1 次操作选择 x 1最优选择能最快修正错误位置找 nums 中 x1 的极大连续区间遍历数组只有索引 0 位置是 1左边无元素、右边是 2不是1所以极大区间是[0, 0]。执行替换把 nums[0] 替换成 target[0]值为2。操作后状态nums[2, 2, 3]target[2, 1, 3]已操作次数1第二步执行第 2 次操作选择 x 2当前唯一需要修正的错误值找 nums 中 x2 的极大连续区间遍历数组索引 0、1 都是 2左边无元素、右边是 3不是2所以极大区间是[0, 1]。执行替换把 nums[0~1] 替换成 target[0~1]nums[0] 原本就是2和target一致不变nums[1] 替换成 target[1]值为1。操作后状态nums[2, 1, 3]target[2, 1, 3]已操作次数2第三步终止此时nums与target完全相等停止操作。最终最少操作次数2三、核心解题思路第一步筛选差异位置遍历两个数组找出所有nums[i] ≠ target[i]的位置这些位置是必须通过操作修正的。第二步统计「需要操作的不同数值」每次操作我们只能选择一个数值x批量修正所有x的极大区间。最少操作次数 所有需要修正的位置中不同数值的数量。示例中需要修正的数值是1和2共2个所以答案是2第三步输出结果直接返回统计到的不同数值的个数就是最少操作次数。四、时间复杂度 额外空间复杂度 分析1. 总时间复杂度核心操作一次完整遍历数组遍历所有元素对比nums和target 哈希表插入/查询操作。数组长度为n哈希表的单次操作是O(1)常数时间。总时间复杂度O(n)线性时间处理10万级数据完全高效2. 总额外空间复杂度额外使用了哈希集合存储需要修正的不同数值。哈希集合的最大元素个数最多等于数组长度n极端情况所有位置都需要修正且数值全不同。总额外空间复杂度O(n)线性空间符合题目数据范围要求总结过程先选数值x→找x的最长连续段→批量替换为目标值重复至数组一致最少操作次数 需要修正的不同数值的个数时间复杂度O(n)线性遍历空间复杂度O(n)哈希集合存储差异数值。Go完整代码如下packagemainimport(fmt)funcminOperations(nums,target[]int)int{set:map[int]struct{}{}fori,x:rangenums{ifx!target[i]{set[x]struct{}{}}}returnlen(set)}funcmain(){nums:[]int{1,2,3}target:[]int{2,1,3}result:minOperations(nums,target)fmt.Println(result)}Python完整代码如下package mainimport(fmt)func minOperations(nums,target[]int)int{set:map[int]struct{}{}fori,x:rangenums{ifx!target[i]{set[x]struct{}{}}}returnlen(set)}func main(){nums:[]int{1,2,3}target:[]int{2,1,3}result:minOperations(nums,target)fmt.Println(result)}C完整代码如下#includeiostream#includevector#includeunordered_setusingnamespacestd;intminOperations(vectorintnums,vectorinttarget){unordered_setintset;for(inti0;inums.size();i){if(nums[i]!target[i]){set.insert(nums[i]);}}returnset.size();}intmain(){vectorintnums{1,2,3};vectorinttarget{2,1,3};intresultminOperations(nums,target);coutresultendl;return0;}

相关文章:

2026-05-21:变成目标数组的最少操作次数。用go语言,给定两个长度相同的数组 nums 和 target。 - nums[i] 表示当前位置 i 当前的值。 - target[i] 表示当前位

2026-05-21:变成目标数组的最少操作次数。用go语言,给你两个长度为 n 的整数数组 nums 和 target。nums[i] 表示当前位置 i 的当前值,target[i] 表示你希望当前位置 i 最终变成的期望值。 你可以进行任意多次操作(可以不做&#x…...

别再被ZIP伪加密骗了!一个Python脚本自动检测修复,解放你的双手

用Python自动化破解ZIP伪加密:从原理到实战工具开发 每次在CTF比赛中遇到ZIP伪加密题目,你是否也厌倦了手动用十六进制编辑器逐个修改字节的繁琐过程?作为参加过数十场CTF比赛的老兵,我深刻理解这种重复劳动的低效与痛苦。本文将带…...

Xilinx Zynq MPSoC开发实战:从Vivado到SDK的Hello World全流程解析

1. 项目概述与核心思路作为一名在嵌入式领域摸爬滚打了十多年的老工程师,每次拿到一块新的高性能开发板,那种想立刻点亮它、跑通第一个程序的冲动,就跟当年攒好第一台电脑按下开机键一样。这次拿到手的是基于Xilinx Zynq UltraScale MPSoC的米…...

人工智能,应用层和算法层到底该怎么选?

想做AI,但是应用层和算法层到底有啥区别?”“我非科班,能学算法吗?”“哪个方向薪资更高、更有前景?”其实不止新手,就连一些转行做AI的从业者,初期也会被这两个方向搞懵。毕竟都属于人工智能领…...

Hitboxer:专业级SOCD按键重映射工具,3分钟解决游戏输入冲突

Hitboxer:专业级SOCD按键重映射工具,3分钟解决游戏输入冲突 【免费下载链接】socd Key remapper for epic gamers 项目地址: https://gitcode.com/gh_mirrors/so/socd 还在为游戏中同时按下相反方向键导致角色卡顿而烦恼吗?Hitboxer是…...

告别串口助手!用手机APP和ESP-01S模块,5分钟搞定51单片机无线控制LED

手机APP直连ESP-01S:零门槛实现51单片机LED无线控制 在物联网原型开发中,摆脱串口助手的束缚,直接用手机APP控制硬件设备,是许多初学者的迫切需求。本文将带你用最常见的ESP-01S模块和任意一款TCP调试APP,在5分钟内搭建…...

AI 时代,软件正在从 “为人设计” 转向 “为 Agent 设计”

软件,正在迎来它的第二张界面。 第一张是给人用的:图形界面、点击交互、视觉导航。过去三十年,所有软件的设计逻辑都建立在一个从未被明说的前提上——使用者是人,靠眼睛判断,靠手操作。 AI Agent 打破了这个前提。它…...

VSCode Mermaid Preview:面向技术团队的实时图表协作解决方案

VSCode Mermaid Preview:面向技术团队的实时图表协作解决方案 【免费下载链接】vscode-mermaid-preview Previews Mermaid diagrams 项目地址: https://gitcode.com/gh_mirrors/vs/vscode-mermaid-preview 在技术文档编写、系统架构设计和项目规划过程中&…...

PotPlayer字幕翻译插件终极指南:5分钟实现免费实时字幕翻译

PotPlayer字幕翻译插件终极指南:5分钟实现免费实时字幕翻译 【免费下载链接】PotPlayer_Subtitle_Translate_Baidu PotPlayer 字幕在线翻译插件 - 百度平台 项目地址: https://gitcode.com/gh_mirrors/po/PotPlayer_Subtitle_Translate_Baidu 还在为外语视频…...

Gmail现可语音对话式检索邮件,亮相Google IO 2026

谷歌在向Gmail注入AI功能的道路上仍未停步。本周二,在年度开发者大会Google IO 2026上,这家科技巨头宣布对Gmail的"AI收件箱"功能进行升级扩展,正式引入对话式AI交互能力。这意味着用户今后可以直接向Gmail发问,而无需再…...

如何使用谷歌全新AI智能体,实现超越普通搜索的信息追踪

在谷歌 I/O 2026 开发者大会主题演讲中,这家科技巨头宣布了搜索功能中全新的智能体能力。用户现在可以创建、自定义并管理多个 AI 智能体,以便持续获取感兴趣话题的最新动态。此次发布是谷歌大力推进智能体 AI 系统战略的重要组成部分,这类系…...

Fluent瞬态计算踩坑记录:时间统计采样设置里的3个关键细节与避坑指南

Fluent瞬态计算时间统计功能深度解析:从原理到实践的3个高阶技巧 在计算流体动力学(CFD)的瞬态仿真中,时间统计功能就像一位隐形的数据分析师,默默记录着流场参数的每一次脉动与演变。许多工程师在使用Fluent进行瞬态计…...

ARM裸机开发:从异常处理到协作式调度器的实战指南

1. 项目概述:从“异常”切入,理解ARM裸机开发的本质如果你刚开始接触ARM嵌入式开发,可能会觉得“异常”这个词有点吓人,听起来像是程序出了什么大问题。但恰恰相反,在ARM裸机开发的世界里,“异常”是系统与…...

UVM寄存器模型简化实践:提升芯片验证效率的封装与自动化方案

1. 项目概述:为什么我们需要简化UVM寄存器模型?如果你在芯片验证领域摸爬滚打过几年,尤其是深度参与过SoC或复杂IP的验证,那么对UVM寄存器模型(UVM Register Model)一定是又爱又恨。爱的是,它提…...

Zynq MPSoC开发实战:从Vivado硬件设计到SDK软件部署全流程解析

1. 项目概述与开发板初探作为一名在嵌入式领域摸爬滚打了十多年的老工程师,每当有新平台、新架构出现时,那种想亲手“点亮”它的冲动总是难以抑制。Xilinx的Zynq UltraScale MPSoC系列就是这样一块“硬骨头”,官方宣称相比经典的Zynq-7000系列…...

从RTL到GDS:STA工程师的一天,如何用DC工具修复时序违例(以Setup Violation为例)

从RTL到GDS:STA工程师的一天,如何用DC工具修复时序违例(以Setup Violation为例) 时钟刚过上午9点,咖啡的香气弥漫在工位周围。作为数字后端工程师,我习惯在晨会前先快速扫描昨晚综合运行的日志文件。今天的…...

阿里云峰会大切换:云计算三十年首换用户,全栈重做能否驱动飞轮?

【阿里云峰会现场,信息量惊人】5月20号,在杭州举办的阿里云峰会,场馆外早已排起长队。原本以为只是例行发布会,进去后却发现展区密度远超预期。AI原生应用全家桶、合作伙伴展台,还有超节点服务器实体,一路看…...

2026年5月19日:谷歌云误停账户致Railway全平台服务中断8小时

事件报告:2026年5月19日 - GCP账户暂停Chandrika Khanduri 与 Cody De Arkland于2026年5月20日发布此报告。据悉,本报告反映了发布时所掌握的信息,可能会根据谷歌云(Google Cloud)的内部审查结果进行更新。影响2026年5…...

别再只用SSH了!深入对比新华三设备Telnet的三种认证模式(None/Password/AAA)及适用场景

新华三设备Telnet认证模式深度解析:从安全权衡到场景适配 在网络设备管理的工具箱里,远程访问协议的选择往往决定了运维效率和安全性之间的平衡点。作为网络管理员,我们常常陷入这样的困境:是选择便捷性还是安全性?是追…...

告别FPN信息瓶颈:手把手图解Gold-YOLO的‘聚合-分发’机制(附代码逐行解读)

告别FPN信息瓶颈:手把手图解Gold-YOLO的‘聚合-分发’机制(附代码逐行解读) 在目标检测领域,YOLO系列模型凭借其出色的实时性能一直占据主导地位。然而,随着应用场景的复杂化,传统特征金字塔网络&#xff…...

告别重启!3DSlicer 5.6.0 下 Python Extension 热重载调试指南

告别重启!3DSlicer 5.6.0 下 Python Extension 热重载调试指南 在3DSlicer的Python扩展开发中,最令人沮丧的莫过于每次修改代码后都需要重启整个应用才能看到效果。这种开发模式不仅效率低下,还会打断开发者的思路。本文将深入探讨如何在3DSl…...

告别网页版!用Alist+RaiDrive把阿里云盘、百度网盘变成电脑本地文件夹(保姆级教程)

一键打造云端硬盘:AlistRaiDrive实现本地化文件管理全攻略 你是否经常在多个云盘平台间频繁切换,忍受着网页端上传下载的龟速?每次想修改云盘里的文档,都得先下载到本地,编辑完再重新上传?今天我要分享的这…...

SpringBoot 启动类 标准写法

package org.example.rabbitmqspringbootdemodemo; // 改成你自己的项目包名import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplicationpublic class RabbitMqDemoApplication {public s…...

Pandas/NumPy数据处理中,科学计数法如何‘隐形’影响你的结果?附解决方案

Pandas/NumPy数据处理中科学计数法的隐形陷阱与实战解决方案 当你处理一组看似普通的销售数据时,可能会遇到这样的情况:某个产品的单价被记录为1.23e-5,而另一个产品的单价则是0.0000123。在肉眼看来,这两个数字似乎相等&#xff…...

SAE J1939请求与响应实战:用PCAN-View抓包分析‘要转速’的全过程

SAE J1939实战解析:从请求转速到数据解码的全链路操作指南 在车载诊断和商用车通信领域,SAE J1939协议如同神经系统般贯穿整个车辆架构。当工程师需要获取发动机转速这类关键参数时,协议中PGN(参数组编号)的请求与响应…...

效率翻倍!OrCAD Capture CIS创建复杂元器件库的实战技巧:LM358与多Part器件管理

效率翻倍!OrCAD Capture CIS创建复杂元器件库的实战技巧:LM358与多Part器件管理 在电子设计领域,元器件库的管理水平直接影响设计效率。许多工程师在使用OrCAD Capture CIS时,面对LM358这类多Part器件或更复杂的异构元件时&#x…...

RT-Thread Studio开发RA2L1:从环境搭建到GPIO输入输出实战

1. 项目概述与核心价值最近在捣鼓瑞萨电子的RA2L1 MCU开发板,想基于RT-Thread Studio这个国产IDE快速上手。我发现很多朋友拿到一块新板子,第一步“点亮LED”或者“读取按键”这个看似简单的操作,往往就卡在了环境搭建上。网上的资料要么过于…...

STM32 FSMC外部存储器接口配置与调试实战指南

1. 项目概述:为什么FSMC是STM32连接外部存储器的“瑞士军刀”如果你玩过STM32,尤其是那些带屏幕、需要大容量数据缓存或者要跑复杂UI的型号,比如F1、F4、H7系列,那你大概率绕不开一个外设:FSMC,全称Flexibl…...

CRM功能解析:覆盖客户、销售、数据、库存、工单全场景

在数字化转型浪潮中,企业对业务管理系统的需求已从单一CRM延伸至客户分层、销售自动化、数据分析、进销存、工单协同的全链路覆盖。不同系统在核心能力的实现逻辑与落地价值上差异显著,本文选取超兔一体云、Attio、Creatio、伙伴云CRM、OKKICRM&#xff…...

量化感知训练中的权重震荡:成因、影响与抑制策略

1. 量化感知训练中的“震荡”现象:一个被忽视的优化陷阱在将神经网络模型部署到手机、摄像头、嵌入式芯片这类资源受限的边缘设备时,量化几乎是必经之路。简单说,量化就是把模型里那些动辄32位的浮点数权重和激活值,压缩成8位、4位…...