兄嘚这是我的位置

本文介绍了一道经典的编程面试题——寻找数组中的重复数字,并提供了三种解决方案:排序遍历法、哈希表法及原地置换法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天给大家带来的是一道剑指offer上的题目,也是一道很经典的题目,经常在面试中出现,题目很简单,大家记得打卡呀。

下面我们来看一下题目描述

题目说明:在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。

示例 1:

输入:[2, 3, 1, 0, 2, 5, 3] 输出:2 或 3

题目解析:该题题意很容易理解,只需要找出数组中的某一重复出现的数字即可。

排序遍历法:

我们今天主要通过三种做法解决该题,第一种方法我们可以先对其排序,然后进行遍历当发现重复元素时我们直接返回该元素即可,这种方法比较容易理解,也比较容易实现。

哈希表:

第二种方法就是借助我们的哈希表,遍历数组,利用哈希表存储遇到的数字,如果哈希表已经存储过该数字则直接返回即可。这种方法也比较简单。

下面我们来看代码吧

原地置换:

下面我们看一下这个原地置换法,原地置换的总体思路就是将我们的元素放到他的索引位置。我们可以这样理解,每个人都有自己的位置,我们需要和别人调换回到属于自己的位置,调换之后,如果发现我们的位置上有人了,则返回。大致意思了解了,下面看代码的执行过程。

题目代码:

总的来说今天的题目比较简单,最后的原地置换法,性能较好,大家可以自己实现 一下,这种解题方法也可以用在其他题目上面。大家记得打卡呀。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值