标签:++ bsp 解法 排序 一半 ber 输入 描述 range
找到数组中超过一半的数,即众数。设置一个变量tmp保存当前假设认为是众数的数,设置cnt保存tmp未被抵消的次数。遍历数组,若当前数字不是tmp,则cnt--;若当前数字是tmp,则cnt++;若cnt=0,则tmp换成下一个数字。
这是时间复杂度为O(n),空间复杂度O(1)的最优解。
# -*- coding:utf-8 -*-
class Solution:
def MoreThanHalfNum_Solution(self, numbers):
# write code here
tmp = -1
cnt = 0
for i in range(len(numbers)):
if cnt==0:
tmp = numbers[i]
cnt+=1
else:
if numbers[i]==tmp:
cnt+=1
else:
cnt-=1
sum=0
for k in numbers:
if k==tmp: sum+=1
if sum >= len(numbers)/2+1:
return tmp
else:return 0
将数组排序,然后找到众数
时间复杂度O(nlogn)
空间复杂度O(1)
为数组建立一个字典,遍历数组,得出每个数字出现的次数。
时间复杂度O(n)
空间复杂度O(n)
剑指offer二刷——数组专题——数组中出现次数超过一半的数字
标签:++ bsp 解法 排序 一半 ber 输入 描述 range
原文地址:https://www.cnblogs.com/Olebaba/p/13473140.html