前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >兄嘚这是我的位置

兄嘚这是我的位置

作者头像
公众号袁厨的算法小屋
发布2020-11-25 09:49:36
2770
发布2020-11-25 09:49:36
举报

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

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

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

示例 1:

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

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

排序遍历法:

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

哈希表:

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

下面我们来看代码吧

原地置换:

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

题目代码:

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

扫码关注【袁厨的算法小屋】,让我们一起领略代码的魅力吧。长按扫一扫在这里你一定有所收获。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-11-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 袁厨的算法小屋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档