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

LeetCode 215题解 | 数组中的第K个最大元素

数组中的第K个最大元素

  • 一、题目链接
  • 二、题目
  • 三、算法原理
  • 四、编写代码

一、题目链接

数组中的第K个最大元素

二、题目

在这里插入图片描述

三、算法原理

  • 法一:排序

  • 法二:优先级队列(堆)

重点看法二:

默认建大堆,意味着以后不用自己写堆了,直接用库里的优先级队列即可。

这个问题就是topK问题,只不过不是求解K个最大的,而是要求解第K个最大的。

如何建堆?—— 调用优先级队列的构造接口时底层就会调用建堆算法。

pop 前k-1个数据,再取堆顶元素即可。

四、编写代码

class Solution {
public:int findKthLargest(vector<int>& nums, int k) {priority_queue<int> pq(nums.begin(), nums.end());while (--k){pq.pop();}return pq.top();}
};
http://www.xdnf.cn/news/385093.html

相关文章:

  • oracle 会话管理
  • Java常用类-比较器
  • 卫宁健康WiNGPT3.0与WiNEX Copilot 2.2:医疗AI创新的双轮驱动分析
  • KaiwuDB 2.0:为 AIoT 而生,融合时序、关系与 AI 的未来数据库
  • 四、Hive DDL表定义、数据类型、SerDe 与分隔符核心
  • Linux电源管理(9)_wakelocks
  • 百度AI战略解析:文心一言与自动驾驶的双轮驱动
  • 前端npm包发布流程:从准备到上线的完整指南
  • 大模型都有哪些超参数
  • AUTOSAR图解==>AUTOSAR_TR_AIDesignPatternsCatalogue
  • 深入理解设计模式之原型模式(Prototype Pattern)
  • 深入解析PyTorch中MultiheadAttention的隐藏参数add_bias_kv与add_zero_attn
  • 人工智能100问☞第20问:神经网络的基本原理是什么?
  • 搭建基于chrony+OpenSSL(NTS协议)多层级可信时间同步服务
  • 【系统架构师】2025论文《系统可靠性设计》【含记忆口诀】
  • python打卡day22@浙大疏锦行
  • n8n中订阅MQTT数据
  • JavaScript事件处理全解析:从基础到最佳实践
  • 六大设计模式--OCP(开闭原则):构建可扩展软件的基石
  • 【leetcode】《BFS扫荡术:如何用广度优搜索征服岛屿问题》
  • 深度解析大模型学习率:优化策略与挑战
  • Maven 公司内部私服中央仓库搭建 局域网仓库 资源共享 依赖包构建共享
  • 网络IP分片
  • Spring Web MVC响应
  • SaaS场快订首页的前端搭建【持续更新】
  • MacOS Python3安装
  • Vue Router
  • 【Linux系统】第四节—详解yum+vim
  • Java原生结合MQTTX---完成心跳对话(附带源码)
  • 同一个虚拟环境中conda和pip安装的文件存储位置解析