我是靠谱客的博主 顺利汽车,最近开发中收集的这篇文章主要介绍剑指Offer(Python)—— 数组中重复的数字(简单)数组中重复的数字方法一:暴力循环方法二:栈方法三:哈希表总结,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

数组中重复的数字

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

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

方法一:暴力循环

思路:容易想到的是先排序后遍历,如果前后值相等,则返回。

# 暴力循环
class Solution:
    def findRepeatNumber(self, nums: List[int]) -> int:
        nums.sort()
        n = len(nums)
        for i in range(n - 1):
            if nums[i] == nums[i + 1]:
                return nums[i]
        return []

方法二:栈

思路:此方法在暴力循环的基础上进行了改进。利用栈后进先出(Last In First Out, LIFO)的特点,进行反向检索,如果值不等,弹栈。

# 栈
class Solution:
    def findRepeatNumber(self, nums: List[int]) -> int:
        nums.sort()
        n = len(nums)
        while n >= 0:
            if nums[-1] != nums[-2]:
                nums.pop()
            else:
                return nums[-1]
        return []

方法三:哈希表

思路:利用哈希表(Set)记录数组的各个数字,当查找到重复数字则直接返回。

# 哈希表
class Solution:
    def findRepeatNumber(self, nums: List[int]) -> int:
        nums_dict = set()
        for i in nums:
            if i in nums_dict:
                return i
            nums_dict.add(i)
        return []

总结

Easy!索然无味~

最后

以上就是顺利汽车为你收集整理的剑指Offer(Python)—— 数组中重复的数字(简单)数组中重复的数字方法一:暴力循环方法二:栈方法三:哈希表总结的全部内容,希望文章能够帮你解决剑指Offer(Python)—— 数组中重复的数字(简单)数组中重复的数字方法一:暴力循环方法二:栈方法三:哈希表总结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部