news 2026/4/16 14:13:03

第 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/16 0:17:00

第 476 场周赛Q2——3746. 等量移除后的字符串最小长度

题目链接&#xff1a;3746. 等量移除后的字符串最小长度&#xff08;中等&#xff09; 算法原理&#xff1a; 解法&#xff1a;统计后作差 5ms击败71.03% 时间复杂度O(N) 思路很简单&#xff0c;因为只要数量a和b的数量相同就能删掉&#xff0c;遍历字符串统计a和b的出现次数&a…

作者头像 李华
网站建设 2026/4/16 2:49:57

Java毕设选题推荐: 基于SpringBoot的智慧医疗门诊预约平台基于springboot的智慧医疗网上预约系统【附源码、mysql、文档、调试+代码讲解+全bao等】

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

作者头像 李华
网站建设 2026/4/16 13:33:51

python mqgg 发送 json 文件

pip install paho-mqtt 发送json&#xff0c;含有音频文件&#xff1b; import json, base64 import paho.mqtt.client as mqtt import timedef on_connect(client, userdata, flags, rc):if rc 0:print("[A] Connected to broker")client.subscribe(TOPIC_SUB)pri…

作者头像 李华
网站建设 2026/4/16 13:42:58

springboot_ssm808图书借阅挂失崔还系统功能全--论文

目录具体实现截图摘要系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 摘要 随着信息化技术的快速发展&#xff0c;图书馆管理系统逐渐从传统的手工管理模式向数字化、智能化方向转变。基于Sprin…

作者头像 李华
网站建设 2026/4/16 13:43:15

【奖励到账】CSDN AI 社区镜像创作激励活动第三批奖励正式发放!

家人们注意啦&#xff01;CSDN AI 社区镜像创作激励活动第二批现金奖励已正式发放&#xff0c;CSDN再次新增开发者 “技术变现” 赛道&#xff0c;还没参与的你&#xff0c;速来 get 这份躺赢攻略&#xff0c;下一批奖励名单说不定就有你&#xff01; 1月21日&#xff1a;第三…

作者头像 李华