当前位置: 首页 > news >正文

【LeetCode】每日一题:数组中的第K大的元素

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。
请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。
你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

解题思路

第一种是快排,快排逻辑是以一个元素作为哨兵,通过头尾指针逼近和交换元素的方法找到该哨兵的位置,此题中额外使用k进行剪枝。

第二种思路是使用堆heapify,这种方式会默认生成一个大根堆,可以通过“ListNode.__lt__ = lambda a, b: a.val < b.val # 让堆可以比较节点大小”,然后直接使用heappop返回当前最小值。

AC代码

class Solution:def findKthLargest(self, nums: List[int], k: int) -> int:# def quicksort(nums, l, r, k):#     if l == r:#         return nums[k]#     i, j, key = l, r, nums[l]#     while i < j:#         while nums[i] < key: i += 1#         while nums[j] > key: j -= 1#         if i < j:#             nums[i], nums[j] = nums[j], nums[i]#     return quicksort(nums, l, j, k) if k <= j else quicksort(nums, i+1, r, k)# return quicksort(nums, 0, len(nums) - 1, k)heapify(nums)temp = 0for _ in range(len(nums) - k + 1):temp = heappop(nums)return temp    
http://www.lryc.cn/news/384528.html

相关文章:

  • Keil5.38ARM,旧编译器(V5)安装
  • 【perl】脚本编程的一些坑案例
  • MIX OTP——使用 GenServer 进行客户端-服务器通信
  • 2024年云安全发展趋势预测
  • java.io.eofexception:ssl peer shut down incorrectly
  • Unity之HTC VIVE Cosmos环境安装(适合新手小白)(一)
  • 入门JavaWeb之 Response 验证码和重定向
  • 2024-06-26 问AI: 在大数据模型中,deep speed 是什么?
  • mobaxterm x11 转发Ubuntu mac
  • python数据分析实训任务三(‘职业’)
  • vscode连接SSH
  • 金融科技行业创新人才培养与引进的重要性及挑战
  • 【C++题解】1714. 输出满足条件的整数4
  • 如何安装和配置 Django 与 Postgres、Nginx 和 Gunicorn
  • Graphwalker基于模型的自动化测试
  • Macbook M1 Fusion安装Debian/Linux
  • ERP收费模式是怎样的?SAP ERP是如何收费的?
  • 如何实现免交互
  • 浏览器userAgent大全及JS判断当前APP
  • 11.异常(java版)
  • 单片机学习记录
  • flask的基本使用1
  • 如何编写时区源文件
  • 植物大战僵尸杂交版v2.1最新整合版,附PC端+安卓端+iOS端安装包+修改器+安装教程!
  • 【5G射频基本架构】
  • 4.任务调度
  • Github 2024-06-27 Go开源项目日报Top10
  • 【D3.js in Action 3 精译】1.2.2 可缩放矢量图形(一)
  • 「C系列」C 排序算法
  • Power BI可视化表格矩阵如何保持样式导出数据?