求主元素问题的一些总结

前言

最近一些同学问我一些关于数据结构的问题,在此做个总结,今天这篇是关于主元素的。
一些简单的解法只给出思想,其他我感觉比较好的方法奉上代码。

问题描述

给定一个整型数组,找出主元素,它在数组中的出现次数严格大于数组元素个数的二分之一。

解法1

简单粗暴的两次循环,记录每个值出现多少次,最后比较次数得到主元素

解法2

使用排序算法(如快速排序),将数组排序,这样处于中间位置的一定是主元素(如果存在)

解法3

使用求中位数的思想,因为主元素是数量大于数组元素个数一半的数,所以这个数组的中位数一定是主元素,因此我们转化为求中位数的思想。
关于中位数,大家可以看一下这篇博客:中位数

解法4

新建一个数组B,初始化全部为0。遍历A数组时,将B[A[i]]++。遍历完之后,再遍历数组B,其值最大的元素(且大于n/2,n为A的长度)的下标即为A的主元素。
这种方法的缺点在于,当A中数据的取值相差过大的时候,B所占用的空间会比较大。
解决的思路是可以建立一个A中元素到某一取值区间的映射,比如,假设A中有10个取值,则将A中的每个取值映射到1~10,这样再建立B即可。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值