1.数组中重复的数字

219 阅读1分钟

找出数组中重复的数字。

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

示例 1:

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

限制:

2 <= n <= 100000

答案:

from collections import Counter
class Solution:
    def findRepeatNumber(self, nums: List[int]) -> int:
        return Counter(nums).most_common(1)[0][0]

解题思路:

1、数组中肯定还有重复的数字。

2、使用Counter计数器来获取重复数量最多的数字,most_common方法

3、一行代码搞定,当然用set写逻辑也是可以实现的,Counter底层也是使用Map 排序,更简便的方法NICE