题目:

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

直接使用Python中的集合,其实也就是哈希表,进行处理,代码如下:

class Solution:
def findRepeatNumber(self, nums: List[int]) -> int:
se = set()
for i in nums:
if i in se:
return i
else:
se.add(i)
return -1

效果还可以

03. 找出数组中重复的数字。_重复数字

作者在书中提到的方法,有些麻烦,还得来回交换, 是用上了所有的条件, 但是时间效率并不是很好

如下

class Solution:
def findRepeatNumber(self, nums: List[int]) -> int:
for i in range(len(nums)):
if i == nums[i]:
continue
while nums[i] != i:
if nums[i] == nums[nums[i]]:
return nums[i]
# 注意 下面这句并不能交换顺序
nums[nums[i]], nums[i] = nums[i], nums[nums[i]]

03. 找出数组中重复的数字。_数组_02