news 2026/7/3 21:19:29

剑指offer-50、数组中重复的数字 _

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
剑指offer-50、数组中重复的数字 _

思路及解答

借用Set

⾸先可能想到的做法,就是借助 set ,如果元素不存在 set 中,就将元素添加进去,如果 set
中包含该元素,就返回该元素即可。如果⼀直都没有重复的,那么最后返回 -1 。

java

public class Solution { public int duplicate(int[] numbers) { if (numbers != null) { Set<Integer> set = new HashSet<>(); for (int i = 0; i < numbers.length; i++) { if (set.contains(numbers[i])) { return numbers[i]; } else { set.add(numbers[i]); } } } return -1; } }
  • 时间复杂度:O(n) ,最差的情况可能遍历完所有的元素
  • 空间复杂度: O(n) ,最⼤需 要set ⼤⼩为 n

借助数组

可以直接借助数组,因为所有数字都在 0 到 n-1 的范围内,⽤⼀个⼤⼩为 n 的数组,就可以对所有的数字进⾏统计个数,如果个数超过 1 ,那么肯定是重复的数字,如果没有重复的数字,则返回 -1 ;

java

public class Solution { public int duplicate(int[] numbers) { if (numbers != null) { int[] nums = new int[numbers.length]; for (int i = 0; i < numbers.length; i++) { if (nums[numbers[i]] == 1) { return numbers[i]; } else { nums[numbers[i]] = 1; } } } return -1; } }

同样这种做法的时间复杂度和空间复杂度都是 O(n) ,并没有优化太多。

那么有没有空间复杂度为O(1) 的做法呢?

操作原数组(最优)

不借助额外的空间,那么就只能操作原数组了。如果没有重复的情况,那么这些数字排序后,数字i 和数组下标i 应该是⼀⼀对应的。不会出现多个数字i 的情况。

基于这个原则,在遍历数组的时候,将元素 i 调整到下标 i 的位置,如果下标i的位置已经有元
素,那么说明冲突了,这个元素肯定是重复的,否则继续调整后⾯的。如果没有发现重复的数字,就返回 -1 。

java

public class Solution { public int duplicate(int[] numbers) { int i = 0; while(i < numbers.length) { if(numbers[i] == i) { i++; continue; } if(numbers[numbers[i]] == numbers[i]) return numbers[i]; int tmp = numbers[i]; numbers[i] = numbers[tmp]; numbers[tmp] = tmp; } return -1; } }

但是上⾯的做法,不适合求解多个重复数字的例⼦,因为调换的时候,很容易将后⾯的数字换到前⾯去,就会导致求解出来不是第⼀个重复的数字(可以⽤来求解任意的重复数字),可能是第2,3... 或者其他的重复数字。譬如: [6,3,2,0,2,5,0] 正确的解应该是 2 ,但是由于第⼀次把 6 和最后
的0 调换了位置,就会导致求解出来的值为 0 。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/3 21:19:15

《光与影:33号远征队》mod管理器配置指南新手教程

一、 多游戏生态支持与核心界面解析 针对《光与影&#xff1a;33号远征队》的模组管理需求&#xff0c;目前市面上已涌现出高度集成的中文模组管理器&#xff0c;极大地降低了玩家的使用门槛。该工具不仅完美适配33号远征队&#xff0c;还全面支持《艾尔登法环》、《生化危机4重…

作者头像 李华
网站建设 2026/7/1 2:52:31

使用vscode编译C++代码

tasks.json{//一个简单的tasks.json示例"version": "2.0.0","tasks": [{"label": "C/C: g build active file", // 任务名称"type": "cppbuild", // 任务类型"command": "/usr/bin/g&qu…

作者头像 李华
网站建设 2026/7/1 2:50:42

Java面试题(带答案)

一、Java 并发与集合1. ConcurrentHashMap 特性30 秒版&#xff1a;JDK 1.7&#xff1a;分段锁&#xff08;Segment&#xff09;&#xff0c;锁粒度比 Hashtable 小JDK 1.8&#xff1a;数组 链表/红黑树&#xff0c;用 CAS synchronized 锁链表头节点支持高并发读写&#xff…

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

2026年买口碑好的TPU薄膜,这些销售厂家值得重点关注!

在鞋服、箱包等行业&#xff0c;TPU薄膜是一种至关重要的材料。随着市场需求的不断增长和产品要求的日益提高&#xff0c;选择一家靠谱的TPU薄膜销售厂家变得尤为关键。在2026年&#xff0c;如果您正在寻找口碑好的TPU薄膜厂家&#xff0c;以下几家值得重点关注。一、泉州市星达…

作者头像 李华