面试经典150题——堆

文章目录

  • 1、数组中的第K个最大元素
    • 1.1 题目链接
    • 1.2 题目描述
    • 1.3 解题代码
    • 1.4 解题思路
  • 2、IPO
    • 2.1 题目链接
    • 2.2 题目描述
    • 2.3 解题代码
    • 2.4 解题思路
  • 3、查找和最小的 K 对数字
    • 3.1 题目链接
    • 3.2 题目描述
    • 3.3 解题代码
    • 3.4 解题思路
  • 4、数据流的中位数
    • 4.1 题目链接
    • 4.2 题目描述
    • 4.3 解题代码
    • 4.4 解题思路


1、数组中的第K个最大元素

1.1 题目链接

点击跳转到题目位置

1.2 题目描述

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

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

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

提示:

  • 1 <= k <= nums.length <= 105
  • -104 <= nums[i] <= 104

1.3 解题代码

class Solution {public int findKthLargest(int[] nums, int k) {int heapSize = nums.length;bulidMaxHeap(nums, heapSize);for(int i = nums.length - 1; i >= nums.length - k + 1; --i){swap(nums, 0, i);--heapSize;maxHeapipy(nums, 0, heapSize);}return nums[0];}public void bulidMaxHeap(int[] nums, int heapSize){for(int i =  heapSize / 2 - 1; i >= 0; --i){maxHeapipy(nums, i, heapSize);}}public void maxHeapipy(int[] nums, int i, int heapSize){int l = i * 2 + 1, r = i * 2 + 2, largest = i;if(l < heapSize && nums[l] > nums[largest]){largest = l;}if(r < heapSize && nums[r] > nums[largest]){largest = r;}if(largest != i){swap(nums, i, largest);maxHeapipy(nums, largest, heapSize);}}public void swap(int[] nums, int i, int j){int temp = nums[i];nums[i] = nums[j];nums[j] = temp;}
}

1.4 解题思路

  1. 建立大根堆。

2、IPO

2.1 题目链接

点击跳转到题目位置

2.2 题目描述

假设 力扣(LeetCode)即将开始 IPO 。为了以更高的价格将股票卖给风险投资公司,力扣 希望在 IPO 之前开展一些项目以增加其资本。 由于资源有限,它只能在 IPO 之前完成最多 k 个不同的项目。帮助 力扣 设计完成最多 k 个不同项目后得到最大总资本的方式。

给你 n 个项目。对于每个项目 i ,它都有一个纯利润 profits[i] ,和启动该项目需要的最小资本 capital[i] 。

最初,你的资本为 w 。当你完成一个项目时,你将获得纯利润,且利润将被添加到你的总资本中。

总而言之,从给定项目中选择 最多 k 个不同项目的列表,以 最大化最终资本 ,并输出最终可获得的最多资本。

答案保证在 32 位有符号整数范围内。

提示:

  • 1 <= k <= 105
  • 0 <= w <= 109
  • n == profits.length
  • n == capital.length
  • 1 <= n <= 105
  • 0 <= profits[i] <= 104
  • 0 <= capital[i] <= 109

2.3 解题代码

class Solution {public int findMaximizedCapital(int k, int w, int[] profits, int[] capital) {int res = w;int n = profits.length;int[][] nums = new int[n][2];for(int i = 0; i < n; ++i){nums[i][0] = profits[i];nums[i][1] = capital[i];}Arrays.sort(nums, (a, b) -> a[1] - b[1]);PriorityQueue<Integer> pq = new PriorityQueue<>((x , y) -> y - x);int idx = 0;while(idx < n && w >= nums[idx][1]){pq.offer(nums[idx][0]);idx++;}while(k > 0 && !pq.isEmpty()){k--;int num = pq.poll();res += num;w += num;while(idx < n && w >= nums[idx][1]){pq.offer(nums[idx][0]);idx++;}}return res;}
}

2.4 解题思路

  1. 创建一个二维数组,存入每一个项目的利润和成本。并且将该二维数组按照成本非递减进行排序。
  2. 创建一个大根堆,利润高的项目在堆顶。
  3. 初始化最终利润为本金,每次取项目前现将满足条件(成本小于等于当前记录的最终利润)的项目放入大根堆中,每次取项目取栈顶即可。

3、查找和最小的 K 对数字

3.1 题目链接

点击跳转到题目位置

3.2 题目描述

给定两个以 非递减顺序排列 的整数数组 nums1 和 nums2 , 以及一个整数 k 。

定义一对值 (u,v),其中第一个元素来自 nums1,第二个元素来自 nums2 。

请找到和最小的 k 个数对 (u1,v1), (u2,v2) … (uk,vk) 。

提示:

  • 1 <= nums1.length, nums2.length <= 105
  • -109 <= nums1[i], nums2[i] <= 109
  • nums1 和 nums2 均为 升序排列
  • 1 <= k <= 104
  • k <= nums1.length * nums2.length

3.3 解题代码

class Solution {public List<List<Integer>> kSmallestPairs(int[] nums1, int[] nums2, int k) {List<List<Integer>> res = new ArrayList<>();PriorityQueue<int []> pq = new PriorityQueue<>(k, (o1, o2)->{return nums1[o1[0]] + nums2[o1[1]] - nums1[o2[0]] - nums2[o2[1]];});int m = nums1.length;int n = nums2.length;for(int i = 0; i < Math.min(m, k); ++i){pq.offer(new int[]{i, 0});}while(!pq.isEmpty() && k > 0){k--;int[] idxPair = pq.poll();List list = new ArrayList<>();list.add(nums1[idxPair[0]]);list.add(nums2[idxPair[1]]);res.add(list);if(idxPair[1] < n - 1){pq.offer(new int[]{idxPair[0], idxPair[1] + 1});}}return res;}
}

3.4 解题思路

  1. 贪心+优先队列。
  2. 优先队列以小根堆的形式,存放的数对下标,其对应的数对值最小的则在堆顶。设m为nums1数组的长度,n为nums2数组的长度,则先取的数对,第一个元素为nums1中前k(m)个元素(如果不足k个取m个)。
  3. 然后开始根据优先队列中的堆顶来取元素,记堆顶元素下标对为(x, y),则可能比堆里面的数小的数对中,最小的是{nums1[x], nums2[y + 1]} (只要y小于n - 1)。

4、数据流的中位数

4.1 题目链接

点击跳转到题目位置

4.2 题目描述

中位数是有序整数列表中的中间值。如果列表的大小是偶数,则没有中间值,中位数是两个中间值的平均值。

  • 例如 arr = [2,3,4] 的中位数是 3 。
  • 例如 arr = [2,3] 的中位数是 (2 + 3) / 2 = 2.5 。
  • 实现 MedianFinder 类:

实现 MedianFinder 类:

  • MedianFinder() 初始化 MedianFinder 对象。
  • void addNum(int num) 将数据流中的整数 num 添加到数据结构中。
  • double findMedian() 返回到目前为止所有元素的中位数。与实际答案相差 10-5 以内的答案将被接受。

提示:

  • -105 <= num <= 105
  • 在调用 findMedian 之前,数据结构中至少有一个元素
  • 最多 5 * 104 次调用 addNum 和 findMedian

4.3 解题代码

class MedianFinder {PriorityQueue<Integer> maxQueue;// 大根堆PriorityQueue<Integer> minQueue;// 小根堆public MedianFinder() {// 保证大根堆中的元素数量大于等于小根堆中的元素数量maxQueue = new PriorityQueue<>(Comparator.reverseOrder());// 大根堆minQueue = new PriorityQueue<>();// 小根堆}public void addNum(int num) {if(maxQueue.isEmpty() || num <= maxQueue.peek()){maxQueue.offer(num);while(maxQueue.size() > minQueue.size() + 1){minQueue.offer(maxQueue.poll());}} else{minQueue.offer(num);while(maxQueue.size() < minQueue.size()){maxQueue.offer(minQueue.poll());}}}public double findMedian() {if(maxQueue.size() > minQueue.size()){// 优先队列中元素总和为return maxQueue.peek();} else{return (maxQueue.peek() + minQueue.peek()) / 2.0;}}
}/*** Your MedianFinder object will be instantiated and called as such:* MedianFinder obj = new MedianFinder();* obj.addNum(num);* double param_2 = obj.findMedian();*/

4.4 解题思路

  1. 用优先队列维持两个堆,一个为大根堆,一个为小根堆,保证大根堆中的元素数量大于等于小根堆中元素的数量,并且最多只能多出一个。
  2. 建两个堆是为了保证,大根堆中的元素都小于等于小根堆中的元素,如果元素总数为奇数的话,中位数就是大根堆的堆顶元素,如果为偶数的话,则是大根堆和小根堆堆顶的元素和取平均值。
  3. 对于插入数字而言,如果插入时大根堆为空或者插入的数小于等于大根堆的堆顶,则插入小根堆中(不影响两个堆的堆顶),此时如果大根堆的堆顶元素数量大于小根堆堆顶的元素数 + 1,则将大根堆的堆顶插入到小根堆中;如果插入时插入的数大于大根堆的堆顶,则插入小根堆中,如果大根堆中的元素个数小于小根堆中的元素个数,则将小根堆的堆顶插入进入大根堆中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/18028.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

wps或office的word接入豆包API(VBA版本)

直接上代码&#xff0c;由于时间匆忙&#xff0c;以后写个详细的教程 #If VBA7 ThenPrivate Declare PtrSafe Function URLDownloadToFile Lib "urlmon" Alias "URLDownloadToFileA" (ByVal pCaller As Long, ByVal szURL As String, ByVal szFileName As…

Redis——优惠券秒杀问题(分布式id、一人多单超卖、乐悲锁、CAS、分布式锁、Redisson)

#想cry 好想cry 目录 1 全局唯一id 1.1 自增ID存在的问题 1.2 分布式ID的需求 1.3 分布式ID的实现方式 1.4 自定义分布式ID生成器&#xff08;示例&#xff09; 1.5 总结 2 优惠券秒杀接口实现 3 单体系统下一人多单超卖问题及解决方案 3.1 问题背景 3.2 超卖问题的…

USB Flash闪存驱动器安全分析(第一部分)

翻译原文链接&#xff1a;Hacking Some More Secure USB Flash Drives (Part I) | SySS Tech Blog 文章翻译总结&#xff1a;文章对一些具有AES硬件加密的USB闪存驱动器的网络安全分析研究。研究由SySS的IT安全专家Matthias Deeg进行&#xff0c;他在2022年初发现了几个安全漏…

[前端] axios网络请求二次封装

一、场景描述 为什么要对axios网络请求进行二次封装? 解决代码的复用&#xff0c;提高可维护性。 —这个有两个方案&#xff1a;一个是二次封装一个是实例化。&#xff08;设置一些公共的参数&#xff0c;然后进行请求&#xff09; 为什么可以解决代码的复用&#xff1a; 这是…

DeepSeek助力:打造属于你的GPTs智能AI助手

文章目录 一、环境准备1.安装必要的工具和库2. 选择合适的开发语言 二、核心技术选型1. 选择适合的AI框架 三、功能实现1. 文本生成与对话交互2. 代码生成与自动补全3. 数据分析与报告生成 四、案例实战1. 搭建一个简单的聊天机器人2. 创建一个代码生成器 五、总结与展望1. 当前…

网络基础 【UDP、TCP】

1.UDP 首先我们学习UDP和TCP协议 要从这三个问题入手 1.报头和有效载荷如何分离、有效载荷如何交付给上一层的协议&#xff1f;2.认识报头3.学习该协议周边的问题 UDP报头 UDP我们先从示意图来讲解&#xff0c;认识报头。 UDP协议首部有16位源端口号&#xff0c;16位目的端…

推荐的、好用的线性稳压器

前言 内容来自B站up主-工科男孙老师的视频 视频内容&#xff1a;测评网友推荐的线性稳压器&#xff0c;以及这些线性稳压器的应用场景。视频链接&#xff1a;除了1117&#xff0c;还有哪些更好用的线性稳压器&#xff1f; 1、1117的缺点 体积太大&#xff0c;浪费主板的空间不…

2025最新出炉--前端面试题九

文章目录 1. Vue 和 React 的使用经验对比2. vue 的 computed 和 watch 有什么区别3. v-model 平时你都怎么使用4. import 和 require 之间什么区别5. 说一下 vue 的缓存组件6. vue3.0 为什么使用 proxy 拦截数据7. 能讲讲 vuex 吗, 刷新页面会怎样8. http1.1 和 http2.0 之间什…

rancher on k3s

本次部署采用3节点的etcd服务2master节点的k3s使用helm部署的ranchervip(keepalived) 一、安装etcd服务 # 准备 3 个节点部署 etcd cd /hskj/tmp wget https://github.com/etcd-io/etcd/releases/download/v3.3.15/etcd-v3.3.15-linux-amd64.tar.gz tar xzvf etcd-v3.3.15-…

NLLB 与 ChatGPT 双向优化:探索翻译模型与语言模型在小语种应用的融合策略

作者&#xff1a;来自 vivo 互联网算法团队- Huang Minghui 本文探讨了 NLLB 翻译模型与 ChatGPT 在小语种应用中的双向优化策略。首先介绍了 NLLB-200 的背景、数据、分词器和模型&#xff0c;以及其与 LLM&#xff08;Large Language Model&#xff09;的异同和协同关系。接着…

无人机图像拼接数据的可视化与制图技术:以植被监测为例

无人机技术在生态环境监测中的应用越来越广泛&#xff0c;尤其是在植被监测领域。通过无人机获取的高分辨率影像数据&#xff0c;结合GIS技术&#xff0c;可以实现对植被覆盖、生长状况等的精确监测与分析。本文将通过一个实际案例&#xff0c;详细讲解无人机图像拼接数据的可视…

ONES 功能上新|ONES Copilot、ONES TestCase、ONES Wiki 新功能一览

ONES Copilot 支持基于当前查看的工作项相关信息&#xff0c;利用 AI 模型&#xff0c;在系统中进行相似工作项的查找&#xff0c;包括基于已关联工作项的相似数据查找。 应用场景&#xff1a; 在查看工作项时&#xff0c;可利用 AI 模型&#xff0c;基于语义相似度&#xff0c…

基于带通滤波的camera脏污检测算法可以完全替代imatest

1.概要 脏污检测算法&#xff0c;基于opencv c实现&#xff0c;便于模组厂快速集成到软件工具中&#xff0c;适用于camera模组厂脏污拦截&#xff0c;特别是对浅脏污具备很好的定位效果&#xff1b;便于画质评价工程师了解camera模组制程的问题提出改善方向。 2.技术介绍 下图…

后勤数据源定制主控室

场景&#xff1a;在学习了解后勤数据源过程中&#xff0c;看到觉得有用的note&#xff0c;分享给大家。 1779063 - 常见问题&#xff1a;关于 LO 数据提取 - 定制主控室&#xff08;事务 LBWE&#xff09; 1.问题&#xff1a; 是否需要为每个应用程序组件下的每个数据源添加池…

云原生AI Agent应用安全防护方案最佳实践(上)

当下&#xff0c;AI Agent代理是一种全新的构建动态和复杂业务场景工作流的方式&#xff0c;利用大语言模型&#xff08;LLM&#xff09;作为推理引擎。这些Agent代理应用能够将复杂的自然语言查询任务分解为多个可执行步骤&#xff0c;并结合迭代反馈循环和自省机制&#xff0…

三格电子——TCP转ProfibusDP网关使用场景

型号&#xff1a; SG-TCP-Profibus(M) 感兴趣可以TB 搜 三格电子 使用场景&#xff1a; ModbusTCP Client 通过 ModbusTCP 控制 Profibus DP 接口设备。 ModbusTCP 侧支持03H、04H、10H 功能码&#xff0c;只支持 1 个client连接&#xff1b; ProfibusDP 侧支持 DP v0。 P…

剑指offer第2版:搜索算法(二分/DFS/BFS)

查找本质就是排除的过程&#xff0c;不外乎顺序查找、二分查找、哈希查找、二叉排序树查找、DFS/BFS查找 一、p39-JZ3 找出数组中重复的数字&#xff08;利用特性&#xff09; 数组中重复的数字_牛客题霸_牛客网 方法1&#xff1a;全部排序再进行逐个扫描找重复。 时间复杂…

小众宝藏分子生物学实验中常用的软件:InSequence

欢迎使用InSequence&#xff0c;正版免费使用&#xff0c;操作友好&#xff0c;小白也能轻松上手哦~ 1. 全新中文界面与更大操作空间 全中文简洁直观的操作界面&#xff0c;常用功能固定至工具栏&#xff0c;随心自定义更改工具栏&#xff0c;让科研人员能够更快速地上手&…

南京观海微电子----整流滤波电路实用

01 变压电路 通常直流稳压电源使用电源变压器来改变输入到后级电路的电压。电源变压器由初级绕组、次级绕组和铁芯组成。初级绕组用来输入电源交流电压&#xff0c;次级绕组输出所需要的交流电压。通俗的说&#xff0c;电源变压器是一种电→磁→电转换器件。即初级的交流电转化…

python 的框架 dash 开发TodoList Web 应用

TodoList Web 应用 项目简介 这是一个基于 Dash 和 SQLAlchemy 的现代化 TodoList Web 应用&#xff0c;提供了简单而强大的待办事项管理功能。 主要特性 添加新的待办事项删除待办事项标记待办事项为已完成/未完成分页展示待办事项列表实时更新和交互 技术栈 PythonDash …