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))
相关推荐
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
To_OC2 天前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
To_OC2 天前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC3 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
To_OC5 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
To_OC6 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
想吃火锅100512 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
凌波粒13 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
退休倒计时13 天前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript