面试高频算法难题:数组中的第K个最大元素

面试高频算法难题:数组中的第K个最大元素

目是什么意思呢?比如给定的无序数组如下:

图片

如果 k=6,也就是要寻找数组中的第6大元素,这个元素是哪一个呢?

显然,数组中第一大的元素是24,第二大的元素是20,第三大的元素是17 …第6大的元素是9

图片

图片图片让我想想啊……

图片对了,我可以先把无序数组排序,然后数出排序后的第k个元素!

方法1:排序法

这是最容易想到的方法,先把无序数组从大到小进行排序,排序后的第k个元素,自然就是数组中的第k大元素。

图片

先进行排序的话,算法时间复杂度是O(nlogn),

性能有些差,有没有更优化的方法?图片图片

图片让我想想啊……

图片对了,我可以维护一个长度为k的数组,有序存储当前k个较大的元素!

方法2:插入法

维护一个长度为k的有序数组A,用于存储已知的k个较大的元素。

接下来遍历原数组,每遍历到一个元素,和数组A中最小的元素相比较,如果小于等于数组A的最小元素,继续遍历;如果大于数组A的最小元素,则插入到数组A中,并把曾经的最小元素“挤出去”。

比如k=3,先把最左侧的7,5,15三个数有序放入数组A当中,代表当前最大的3个数。

图片

这时候,遍历到元素3, 由于3<5,继续遍历。

图片

接下来遍历到17,由于17>5,插入到数组A的合适位置,类似于插入排序,并把原先最小的元素5“挤出去”。

图片

继续遍历原数组,一直遍历到数组的最后一个元素…

最终,数组A中存储的元素是24,20,17,代表着整个数组中最大的3个元素。此

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值