数组中重复数字

2021-02-09 10:19

阅读:491

标签:nlog   off   比较   代码   过程   技术   重复数   col   第一个   

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

1.数组用O(nlogn)排序,然后找出重复数字

2.哈希表 时间和空间都为O(n)

3.从头到尾扫描数组,当扫描到下标为i的数字时,首先比较这个数字(m)是不是等于i,如果是则接着扫描下一个数字;如果不是,则再拿他和第m个数字比较。如果它和第m个数字相等,就找到了一个重复的数字;如果它和第m个数字不相等,就把第i个数字和第m个数字交换,把m放到属于它的位置。接下来再重复这个比较,交换的过程,直到我们发现第一个重复的数字。

剑指offer中的代码:

技术图片

 

数组中重复数字

标签:nlog   off   比较   代码   过程   技术   重复数   col   第一个   

原文地址:https://www.cnblogs.com/libin123/p/12751193.html


评论


亲,登录后才可以留言!