leetcode hot100 215. 数组中的第K个最大元素 medium 堆 快速选择 pivot分区


找第K大元素

暴力解法:排序后取第K个

时间复杂度:O(nlog⁡n)O(n \log n)O(nlogn),取决于排序算法(如快排、归并排序)

空间复杂度:O(1)O(1)O(1) 或 O(n)O(n)O(n),取决于排序实现

python 复制代码
class Solution:
    def findKthLargest(self, nums: List[int], k: int) -> int:
        nums.sort() # 暴力排序
        print(nums)   # 从小到大
        return nums[-k]

快速选择(Quick Select)算法

平均时间复杂度:O(n)

  1. 每次划分大约把数组分成两半,递归只进入一边。
  2. 平均递归深度约为 log n,但每层只处理部分数组,所以平均时间复杂度是 O(n)。

最坏情况:O(n²)(但可通过随机化 pivot 避免)

空间复杂度:O(1)(原地修改数组)

class中自己调自己,用self.

python 复制代码
class Solution:
    def findKthLargest(self, nums: List[int], k: int) -> int:

        # 快速选择(数组在无序状态下,每次抛一半: O(n))(二分法是有序状态下每次抛一半 O(log n))

        # 1. 随机选择一个分组参考值
        center = nums[-1]

        # 2. 分成3个部分
        left = [x for x in nums if x > center]  # 值大于center的
        mid  = [x for x in nums if x == center]  # 值 = center的
        right  = [x for x in nums if x < center]  # 值 < center的

        # 3. 判断 第k大 所在部分
        if k <= len(left):   # 值大于center的个数,超过k个,说明k在左边
            return self.findKthLargest(left,k)  # class中自己调自己,用self.
        elif k <= len(left)+ len(mid): # 第k大的值就=center值,而且可能还有好几个相同值
            return center
        else:  # 在右边
            return self.findKthLargest(right, k-len(left)-len(mid))
相关推荐
水蓝烟雨10 小时前
2359. 找到离给定两个节点最近的节点
算法·leetcode
阿Y加油吧11 小时前
二刷动态规划经典题:从打家劫舍到完全平方数,Java 实现复盘与优化
leetcode
阿Y加油吧11 小时前
二刷 LeetCode:爬楼梯与杨辉三角,Java 实现复盘
java·算法·leetcode
凌波粒11 小时前
LeetCode--101. 对称二叉树(二叉树)
算法·leetcode·职场和发展
_深海凉_11 小时前
LeetCode热题100-二叉树的最大深度
算法·leetcode·职场和发展
_深海凉_12 小时前
LeetCode热题100-二叉树的直径
算法·leetcode·职场和发展
水蓝烟雨12 小时前
3373. 连接两棵树后最大目标节点数目 II
算法·leetcode
YL2004042612 小时前
044二叉搜索树中第K小的元素
数据结构·leetcode
_深海凉_13 小时前
LeetCode热题100-对称二叉树
算法·leetcode·职场和发展
运筹vivo@13 小时前
两数之和(leetcode)
算法·leetcode·职场和发展