news 2026/2/2 6:04:26

第 475 场周赛Q1+Q2——3740. 三个相等元素之间的最小距离 I+3741. 三个相等元素之间的最小距离 II

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第 475 场周赛Q1+Q2——3740. 三个相等元素之间的最小距离 I+3741. 三个相等元素之间的最小距离 II

题目链接:3740. 三个相等元素之间的最小距离 I(简单)

3741. 三个相等元素之间的最小距离 II(中等)

算法原理:

解法一:暴力枚举(3740可通过,但3741题会超时)

8ms击败17.49%

时间复杂度O(N³)

思路很简单,三层for循环依次枚举三个数,如果符合条件就逐步更新最小距离

解法二:哈希表优化

127ms击败46.39%

时间复杂度O(N)

①将数值和下标捆绑在一起存进哈希表,键为数值,值为链表,代表前面数值的下标集合,方便找到每个值的下标

②遍历哈希表,因为数值=数值本身,所以只需要遍历每个数值的下标列表,然后计算最小距离即可

③如果这个数的下标集合>3,说明它是可以计算最小距离作为返回值的

④计算距离的时候可以简单些判断:

i,i+1,i+2三个下标,分别设为x、y、z

去掉绝对值后,距离=(y-x)+(z-y)+(z-x)=2(z-x)=2(index[i+2]-index[i])

Java代码:

class Solution { //解法一:暴力枚举 public int minimumDistance(int[] nums) { int n=nums.length; if(n<3) return -1; int ret=0x3f3f3f3f; for(int i=0;i<n;i++){ for(int j=i+1;j<n;j++){ for(int k=j+1;k<n;k++){ if(nums[i]==nums[j]&&nums[j]==nums[k]) ret=Math.min(ret,Math.abs(i-j)+ Math.abs(j-k)+Math.abs(k-i)); } } } return ret==0x3f3f3f3f?-1:ret; } }
class Solution { //解法二:哈希表优化 public int minimumDistance(int[] nums) { int n=nums.length; if(n<3) return -1; int ret=0x3f3f3f3f; //利用哈希表优化 HashMap<Integer,List<Integer>> hash=new HashMap<>(); //统计每个数值的所有下标 for(int i=0;i<n;i++){ List<Integer> index=hash.getOrDefault(nums[i],new ArrayList<>()); index.add(i); hash.put(nums[i],index); } //遍历每个数值的下标列表,计算最小距离 for(Map.Entry<Integer,List<Integer>> entry:hash.entrySet()){ List<Integer> index=entry.getValue(); int len=index.size(); if(len>=3){ for(int i=0;i<=len-3;i++){ int dist=index.get(i+2)-index.get(i); //此处是去掉绝对值之后,相加得到的简化2*(i+2的位置-i的位置) if(2*dist<ret) ret=2*dist; } } } return ret==0x3f3f3f3f?-1:ret; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 7:23:55

字节面试官:问你C++观察者模式,你答了7点他说不够深

二面技术官问了你一道看似简单的问题&#xff1a;“用C实现一个观察者模式&#xff0c;说说关键点。” 你噼里啪啦说了一通&#xff1a;接口设计、注册注销、通知机制……自我感觉良好。结果他皱了皱眉说&#xff1a;“这些是基础&#xff0c;我想听的是C特有的实现难点。” …

作者头像 李华
网站建设 2026/1/29 22:46:09

全面优化你的Windows,RyTuneX系统全能优化神器

一、简介 RyTuneX​ 是一款基于WinUI 3框架和**.NET 8开发的现代化Windows系统优化工具&#xff0c;专为Windows 10/11**设计。这款windows优化工具提供一站式系统优化解决方案&#xff0c;让用户无需专业知识即可轻松提升系统性能、清理冗余和保护隐私。 ​ 目前是1.6.0 &…

作者头像 李华
网站建设 2026/2/1 23:11:11

springboot_ssm814大学生就业帮助系统--论文

目录具体实现截图摘要系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 摘要 随着高校毕业生数量逐年增加&#xff0c;就业压力日益凸显&#xff0c;传统就业服务模式存在信息不对称、资源分散、效…

作者头像 李华
网站建设 2026/1/30 12:02:10

【计算机毕业设计案例】基于springboot+vue的javaweb宝贝回家走失儿童报备基于springboot的走失儿童认领与登记系统(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华