news 2026/5/27 7:15:02

第 172 场双周赛Q1——3779. 得到互不相同元素的最少操作次数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第 172 场双周赛Q1——3779. 得到互不相同元素的最少操作次数

题目链接:3779. 得到互不相同元素的最少操作次数(中等)

算法原理:

解法:队列+哈希表

213ms击败4.19%

时间复杂度O(N)

①数据初始化:
用队列存原数组元素(记录当前剩余元素);
用 HashMap 统计每个元素的出现次数
②提前终止判断:
若初始数组已无重复元素(哈希表键数量 = 队列长度),直接返回 0
③循环执行删除操作:
每次操作删除队列前 3 个元素,操作次数 + 1;
更新哈希表:对应元素次数减 1,次数为 0 则从表中移除
④操作后检查终止条件:
若剩余元素已无重复(哈希表键数量 = 当前队列长度),立即返回当前操作次数
⑤处理剩余不足 3 个的元素:
若剩余元素不足 3 个,需额外 1 次操作(删除剩余元素),返回次数 + 1
循环结束后,返回总操作次数

Java代码:

class Solution { public int minOperations(int[] nums) { int n=nums.length; Queue<Integer> q=new LinkedList<>(); //存<数,出现次数> Map<Integer,Integer> hash=new HashMap<>(); for(int x:nums){ q.offer(x); hash.put(x,hash.getOrDefault(x,0)+1); } //所有元素均不重复就立刻返回 if(hash.keySet().size()==q.size()) return 0; int ret=0; //数组不空且不包含任何重复元素才进入循环 while(!q.isEmpty()&&hash.keySet().size()!=q.size()){ if(q.size()<3) return ret+1; for(int i=0;i<3;i++){ int out=q.poll(); hash.put(out,hash.get(out)-1); if(hash.get(out)==0) hash.remove(out); } ret++; //如果剩余元素均不重复,直接返回结果 if(hash.keySet().size()==q.size()) return ret; } return ret; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 23:50:18

接口测试的分水岭时刻:Open-AutoGLM能否彻底取代Postman?真相令人意外

第一章&#xff1a;接口测试的分水岭时刻在软件测试的发展历程中&#xff0c;接口测试的兴起标志着从传统UI驱动验证向更高效、稳定和可维护的测试策略转型的关键节点。随着微服务架构的普及&#xff0c;系统间的依赖更多地通过API进行交互&#xff0c;使得接口成为质量保障的核…

作者头像 李华
网站建设 2026/5/26 4:56:14

Thinkphp和Laravel仓库火情火灾消防监测报警系统前vue端

目录具体实现截图项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理具体实现截图 本系统&#xff08;程序源码数据库调试部署讲解&#xff09;带文档1万字以上 同行可拿货,招校园代理 Thinkphp和Laravel仓库火情火灾消防监测报警系统前vue端 项…

作者头像 李华
网站建设 2026/5/26 10:07:46

Thinkphp和Laravel宠屋”宠物交易商城购物网站的设计与实现-vue

目录具体实现截图项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理具体实现截图 本系统&#xff08;程序源码数据库调试部署讲解&#xff09;带文档1万字以上 同行可拿货,招校园代理 Thinkphp和Laravel宠屋”宠物交易商城购物网站的设计与实现-vu…

作者头像 李华
网站建设 2026/5/26 1:33:54

还在为自动化脚本迁移头疼?Open-AutoGLM与Tosca API层适配差异一文讲透

第一章&#xff1a;自动化脚本迁移的现状与挑战随着企业IT基础设施的不断演进&#xff0c;自动化脚本在系统部署、配置管理、监控告警等场景中扮演着核心角色。然而&#xff0c;当组织从传统架构向云原生或混合云环境过渡时&#xff0c;原有自动化脚本面临兼容性差、维护成本高…

作者头像 李华
网站建设 2026/5/25 17:58:57

为什么顶尖团队都在弃用SoapUI转向Open-AutoGLM?真相就在这3大协同差异

第一章&#xff1a;从SoapUI到Open-AutoGLM&#xff1a;协同演进的必然趋势随着API生态的持续扩张与智能化测试需求的崛起&#xff0c;传统接口测试工具如SoapUI已难以满足现代开发对自动化、语义理解与智能生成的复合要求。在这一背景下&#xff0c;Open-AutoGLM作为融合大语言…

作者头像 李华
网站建设 2026/5/26 1:33:08

深入理解 Java Web 开发中的 HttpServletRequest 与 HttpServletResponse

前言 在 Java Web 开发中&#xff0c;尤其是基于 Servlet 规范构建的后端系统&#xff08;如 Spring Boot 应用&#xff09;&#xff0c;我们经常会看到 Controller 方法中出现如下参数&#xff1a; GetMapping("/example") public void handleRequest(HttpServletRe…

作者头像 李华