这次在刷Leetcode
时,在求解数组中的第K
大问题时,想到了使用堆排序,因此本篇文章用于巩固对堆排序的学习以及代码实现。
题目描述:在未排序的数组中找到第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。
输入:[3,2,3,1,2,4,5,5,6] 和 k = 4
输出:4
当时看到此题时,第一反应就是想到使用大顶堆来求解,在第K
次调堆后,就能够得到最K
大元素。后续以大顶堆进行为例。
先来简单回顾堆排序:堆是一棵完全二叉树。如果是一个大顶堆,则根节点递归的大于其左右孩子节点的值。
以大顶堆为例:(3,2,3,1,2,4,5,5,6)
,对该待排序列进行堆排序。