找出数组中出现次数超过一半的数

栏目: Python · 发布时间: 5年前

内容简介:面试遇到的题目,数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。不考虑效率,采用最简单的办法,遍历数组,使用 List 的 count() 方法统计元素出现的次数:构造一个map,key为元素的值,value为元素出现的次数,然后遍历map找到目标元素:

面试遇到的题目,数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。

计数+比较

不考虑效率,采用最简单的办法,遍历数组,使用 List 的 count() 方法统计元素出现的次数:

def more_than_half_num(arr):
    half = len(arr) // 2
    for i in arr:
        if arr.count(i) > half:
            return i
    return None

构造一个map,key为元素的值,value为元素出现的次数,然后遍历map找到目标元素:

def more_than_half_num(arr):
    dict = {}
    for i in arr:
        if i in dict:
            dict[i] += 1
        else:
            dict[i] = 1

    half = len(arr) // 2
    for k, v in dict.items():
        if v > half:
            return k
    return None

排序+中位数

数组 排序 后,如果符合条件的数存在,则一定是数组中间那个数。可使用 排序算法 对数组进行排序,然后求排序后数组的中间数 + 判断中间数出现次数是否超过数组的一半。下面以快速排序为例:

def part_sort(arr, left, right):
    key = right
    while left < right:
        while left < right and arr[left] <= arr[key]:
            left += 1
        while left < right and arr[right] >= arr[key]:
            right -= 1
        arr[left], arr[right] = arr[right], arr[left]
        print(arr)
    arr[left], arr[key] = arr[key], arr[left]
    return left


def quick_sort(arr, left, right):
    if left >= right:
        return
    index = part_sort(arr, left, right)
    quick_sort(arr, left, index - 1)
    quick_sort(arr, index, right)


def more_than_half_num(arr):
    length = len(arr)
    quick_sort(arr, 0, length - 1)
    res = arr[length // 2]
    if arr.count(res) > length // 2:
        return res
    else:
    	return None

一次遍历

数组中有一个数字出现的次数超过数组长度的一半,也就是说出现的次数比其他所有数字出现次数的和还要多。因此我们可以考虑在遍历数组的时候利用两个辅助变量,一个记录数字出现的次数,一个记录数字。

  • 当我们遍历到下一个数字的时候,如果下一个数字和我们之前保存的数字相同,则次数加1;
  • 如果下一个数字和我们之前保存的数字不同,则次数减1。
  • 如果次数为零,我们需要保存下一个数字,并把次数设为1。
def more_than_half_num(arr):
    res = arr[0]
    cnt = 1
    for i in range(1, len(arr)):
        if arr[i] == res:
            cnt += 1
        else:
            cnt -= 1
        if cnt == 0:
            res = arr[i]
            cnt = 1
    if arr.count(res) > len(arr)//2:
        return res
    else:
        return None

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

硅谷增长黑客实战笔记

硅谷增长黑客实战笔记

曲卉 / 机械工业出版社 / 2018-4-10 / 65.00元

增长黑客这个词源于硅谷,简单说,这是一群以数据驱动营销、以迭代验证策略,通过技术手段实现爆发式增长的新型人才。近年来,互联网公司意识到这一角色可以发挥四两拨千斤的作用,因此对该职位的需求也如井喷式增长。 本书作者曾在增长黑客之父肖恩•埃利斯麾下担任增长负责人,用亲身经历为你总结出增长黑客必备的套路、内力和兵法。本书不仅有逻辑清晰的理论体系、干货满满的实践心得,还有Pinterest、SoFi......一起来看看 《硅谷增长黑客实战笔记》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具