news 2026/4/22 23:00:39

第 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/4/18 2:52:08

滴滴 wsgsig secdd-challenge

声明 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由 此产生的一切后果均与作者无关&#xff01; 部分python代码 url "ota/re…

作者头像 李华
网站建设 2026/4/18 12:28:02

深入解析不安全反序列化漏洞与防护[高风险]

博主正在参加CSDN博客之星评选&#xff0c;需要您的支持&#xff01; 投票链接&#xff1a;https://www.csdn.net/blogstar2025/detail/056 在构建现代应用程序时&#xff0c;数据的持久化与传输是核心需求。我们常常需要将内存中结构复杂的对象“压扁”成字节流或文本&#x…

作者头像 李华
网站建设 2026/4/19 23:48:20

springboot_ssm810基于SSM的校园音乐平台--论文

目录 具体实现截图摘要 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 摘要 随着互联网技术的快速发展&#xff0c;校园音乐文化逐渐成为学生生活的重要组成部分。传统的校园音乐活动受限于时…

作者头像 李华
网站建设 2026/4/16 19:20:06

springboot_ssm817学生信息管理系统--论文

目录 具体实现截图摘要 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 摘要 随着信息技术的快速发展&#xff0c;高校学生信息管理系统的智能化、高效化需求日益增长。传统的纸质或单机版管理…

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

基于SpringBoot+Vue一鹿租车公司车辆管理系统的设计与实现

博主主页&#xff1a;一点素材 博主简介&#xff1a;专注Java技术领域和毕业设计项目实战、Java微信小程序、安卓等技术开发&#xff0c;远程调试部署、代码讲解、文档指导、ppt制作等技术指导。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬…

作者头像 李华