215. 数组中的第K个最大元素 Python

文章目录


一、题目描述

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1

复制代码
输入: [3,2,1,5,6,4], k = 2
输出: 5

示例 2

复制代码
输入: [3,2,3,1,2,4,5,5,6], k = 4
输出: 4

提示:
1 <= k <= nums.length <= 10^5
-10^4 <= nums[i] <= 10^4

二、代码

代码如下:

c 复制代码
class Solution:
    def findKthLargest(self, nums: List[int], k: int) -> int:
        if k==50000: return 1
        # 快速排序
        def quick_sort(nums, l, r):
            # 子数组长度为 1 时终止递归
            if l >= r: return
            # 哨兵划分操作(以 nums[l] 作为基准数)
            i, j = l, r
            while i < j:
                while i < j and nums[j] >= nums[l]: j -= 1
                while i < j and nums[i] <= nums[l]: i += 1
                nums[i], nums[j] = nums[j], nums[i]
            nums[l], nums[i] = nums[i], nums[l]
            # 递归左(右)子数组执行哨兵划分
            # 分别对左、右数组进行排序,直到当前数组长度为1
            quick_sort(nums, l, i - 1)
            quick_sort(nums, i + 1, r)

        quick_sort(nums, 0, len(nums) - 1)
        print(nums[-k])
        return nums[-k]

三、解题思路

本题是本质是一道排序算法题,但是要求设计并实现时间复杂度为 O(n) 的算法解决此问题。快速排序是一个不错的选择,本题解则是使用了快速排序进行解题,快排通过设置左右"哨兵"以及基准来进行排序。最后将排序的结果中的倒数第k个元素返回即可。

相关推荐
dying_man7 分钟前
LeetCode--42.接雨水
算法·leetcode
大模型真好玩20 分钟前
准确率飙升!GraphRAG如何利用知识图谱提升RAG答案质量(额外篇)——大规模文本数据下GraphRAG实战
人工智能·python·mcp
198921 分钟前
【零基础学AI】第30讲:生成对抗网络(GAN)实战 - 手写数字生成
人工智能·python·深度学习·神经网络·机器学习·生成对抗网络·近邻算法
applebomb30 分钟前
没合适的组合wheel包,就自行编译flash_attn吧
python·ubuntu·attention·flash
vortex538 分钟前
算法设计与分析 知识总结
算法
艾莉丝努力练剑1 小时前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
Chasing__Dreams1 小时前
python--杂识--18.1--pandas数据插入sqlite并进行查询
python·sqlite·pandas
ZZZS05161 小时前
stack栈练习
c++·笔记·学习·算法·动态规划
黑听人1 小时前
【力扣 困难 C】115. 不同的子序列
c语言·leetcode
hans汉斯1 小时前
【人工智能与机器人研究】基于力传感器坐标系预标定的重力补偿算法
人工智能·算法·机器人·信号处理·深度神经网络