我是靠谱客的博主 顺利汽车,最近开发中收集的这篇文章主要介绍剑指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)—— 数组中重复的数字(简单)数组中重复的数字方法一:暴力循环方法二:栈方法三:哈希表总结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复