Python面试宝典第30题:找出第K大元素

题目

        给定一个整数数组nums,请找出数组中第K大的数,保证答案存在。其中,1 <= K <= nums数组长度。

        示例 1:

输入:nums = [3, 2, 1, 5, 6, 4], K = 2
输出:5

        示例 2:

输入:nums = [50, 23, 66, 18, 72], K = 3
输出:50

快速选择算法

        快速选择算法的基本思想是:通过一次划分操作,将数组分为两部分,使得一部分的所有元素都小于另一部分的所有元素;如果K正好位于划分点,则我们找到了答案;否则,我们只需要在较小的那一部分中继续寻找。使用快速选择算法求解本题的主要步骤如下。

        1、选取一个基准元素pivot。

        2、对数组进行划分,使得所有小于pivot的元素都在其左侧,所有大于pivot的元素都在其右侧。

        3、根据pivot的位置,决定下一步的操作。

        (1)如果pivot的位置正好是K-1,那么pivot就是我们要找的第K大的元素。

        (2)如果pivot的位置大于K-1,那么我们需要在左侧子数组中继续查找。

        (3)如果pivot的位置小于K-1,那么我们需要在右侧子数组中继续查找。

        4、重复上述步骤,直到找到最终答案。

        根据上面的算法步骤,我们可以得出下面的示例代码。

def partition(nums, left, right):# 选择最右边的元素作为基准pivot = nums[right]i = leftfor j in range(left, right):if nums[j] < pivot:nums[i], nums[j] = nums[j], nums[i]i += 1nums[i], nums[right] = nums[right], nums[i]return idef quickselect(nums, left, right, k):if left == right:return nums[left]pivot_index = partition(nums, left, right)# 判断基准的位置if k == pivot_index + 1:return nums[k - 1]elif k < pivot_index + 1:return quickselect(nums, left, pivot_index - 1, k)else:return quickselect(nums, pivot_index + 1, right, k)def find_Kth_largest_element_by_quick_select(nums, k):# 因为数组索引从0开始,而题目要求的是第k大的数,所以需要转换为第n-k+1小的数  n = len(nums)return quickselect(nums, 0, n - 1, n - k + 1)nums = [3, 2, 1, 5, 6, 4]
k = 2
print(find_Kth_largest_element_by_quick_select(nums, k))nums = [50, 23, 66, 18, 72]
k = 3
print(find_Kth_largest_element_by_quick_select(nums, k))

堆排序法

        堆排序法的基本思想是:利用最小堆的性质来维护一个大小为K的堆,这样我们就可以在遍历数组的过程中不断更新这个堆,最终堆顶的元素就是我们要找的第K大的数。使用堆排序法求解本题的主要步骤如下。

        根据上面的算法步骤,我们可以得出下面的示例代码。

        1、导入heapq模块,使用它提供的heappush和heappop函数来操作堆。

        2、创建一个大小为K的空堆。

        3、遍历数组nums,对于每个元素x,进行以下操作。

        (1)如果堆的大小小于K,则直接将x插入堆中。

        (2)如果堆的大小等于K且x大于堆顶元素,则弹出堆顶元素,并将x插入堆中。

        4、最终,堆顶元素即为第K大的元素。

import heapqdef find_Kth_largest_element_by_min_heap(nums, k):# 创建一个大小为k的最小堆min_heap = []# 遍历数组中的每一个元素for num in nums:# 如果堆的大小小于k,则直接插入if len(min_heap) < k:heapq.heappush(min_heap, num)# 如果堆已满并且当前元素比堆顶元素大,则替换堆顶元素elif num > min_heap[0]:heapq.heapreplace(min_heap, num)# 堆顶元素即为第k大的元素return min_heap[0]nums = [3, 2, 1, 5, 6, 4]
k = 2
print(find_Kth_largest_element_by_min_heap(nums, k))nums = [50, 23, 66, 18, 72]
k = 3
print(find_Kth_largest_element_by_min_heap(nums, k))

总结

        快速选择算法的时间复杂度平均情况下为O(n),最坏情况下(每次选择的基准都是最小或最大值时)为O(n^2)。由于最坏情况下的性能较差,一般需要随机化选择基准来避免最坏情况的发生。堆排序法的时间复杂度为O(n*logK),这是因为每次插入和删除操作的时间复杂度为O(logK),总共有n次操作。

        总的来说,快速选择算法适用于大多数情况,特别是在K接近数组长度一半时。它不需要额外的存储空间(除了递归栈),而且通常情况下性能很好。堆排序法更适合于K相对于数组长度较小的情况,因为随着K的增加,性能会逐渐变差。另外,它需要额外的存储空间来维护堆。

💡 如果想阅读最新的文章,或者有技术问题需要交流和沟通,可搜索并关注微信公众号“希望睿智”。

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

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

相关文章

Rest风格快速开发

Rest风格开发简介 简单点来说&#xff0c;Rest风格的开发就是让别人不知道你在做什么&#xff0c;以deleteUserById和selectUserById为例&#xff1a; 普通开发&#xff1a;路径 /users/deleteById?Id666 /users/selectById?Id666 别人很容易知道你这是在干什么 Rest风…

JavaScript骚操作媒体查询攻略

背景 一讲到媒体查询&#xff0c;大家首先想到的可能都是都是CSS中media,这也没错&#xff0c;这确实是最常见的媒体查询方式&#xff0c;但是我们今天要讲的不是它&#xff0c;而是大家很少接触到的window.matchMedia()和window.resize 最近在做项目的时候拿到一个需求&…

【Qt】多种控件实现“hello world“

使用编辑框的方式实现"hello wordl" 使用编辑框实现"hello world"的方式有俩种&#xff1a; 单行编辑框&#xff1a;LineEdit多行编辑框&#xff1a;TextEdit 图形化界面 纯代码方式 代码展示&#xff1a; #include "widget.h" #include &qu…

Python实战:基础语法

一、求解列表中的最大元素 import random#定义函数 def get_max(lst):x lst[0] #x存储的是元素的最大值#遍历操作for i in range(1,len(lst)):if lst[i] > x:x lst[i] #对最大值进行重新赋值return x#调用函数 lst [random.randint(1,100) for item in range(10)] print…

YARN 调度器的配置与使用

YARN 调度器的配置与使用 一、启动公平调度器1.1 配置 yarn-site.xml创建 fail-scheduler.xml 文件 二、同步配置文件三、重启启动 YARN 集群四、提交作业五、运行结果 一、启动公平调度器 公平调度器的使用由属性yarn.resourcemanager.scheduler.class的设置所决定。YARN默认…

mybatis-plus雪花算法

苞米豆mybatis-plus已实现雪花算法&#xff0c;若项目中使用雪花算法生成自增主键&#xff0c;可直接引用相关jar实现其工具类&#xff0c;若不想再单独引用jar也可将其Sequence类直接复制到自己项目中定义为工具类使用 官方文档&#xff1a;https://baomidou.com/ Git地址&am…

C++ | Leetcode C++题解之第330题按要求补齐数组

题目&#xff1a; 题解&#xff1a; class Solution { public:int minPatches(vector<int>& nums, int n) {int patches 0;long long x 1;int length nums.size(), index 0;while (x < n) {if (index < length && nums[index] < x) {x nums[i…

基于python的百度迁徙迁入、迁出数据分析(七)

参考&#xff1a;【Python】基于Python的百度迁徙2——迁徙规模指数&#xff08;附代码&#xff09;-CSDN博客 记录于2024年8月&#xff0c;这篇是获取百度迁徙指数&#xff0c;之前我们都在讨论不同城市的迁徙比例关系&#xff0c;这篇我们来获取百度迁徙指数这个数据&#x…

职场要懂“3不急”,否则走不远

在职场中&#xff0c;我们经常会遇到各种各样的人和事&#xff0c;有的同事能够得到领导的重视和喜爱&#xff0c;有的则始终处于“不温不火”的状态&#xff0c;这其中到底是什么原因导致的呢&#xff1f; 其实&#xff0c;很大一部分原因是因为在工作中犯了一些“急于表现”…

Vue - progressive-image 渐进式图片加载(Vue2)

Vue - progressive-image 渐进式图片加载&#xff08;Vue2&#xff09; 在追求高分辨率图片的网页中&#xff0c;其图片加载速度影响着用户的体验&#xff0c;特别在低网速加载慢的情况下&#xff0c;简单的图片加载图标无法满足用户需求&#xff0c;progressive-image实现了渐…

硬盘文件数据销毁|文件销毁|硬盘销毁|数据销毁|中国成就的伟大与数据安全在新时代国家安全中的关键作用

在当今世界&#xff0c;中国的发展成就举世瞩目&#xff0c;但令人惊讶的是&#xff0c;大多数人可能并未充分意识到其伟大之处。与此同时&#xff0c;数据安全作为国家安全的重要组成部分&#xff0c;其重要性在新时代愈发凸显。 二、中国取得的伟大成就 中国在经济领域的崛起…

mp4视频声音小怎么增强放大?全网视频声音增强放大的方法汇总

在观看或编辑MP4视频时&#xff0c;声音作为传递情感、信息和氛围的关键元素&#xff0c;其质量往往直接决定了观众的沉浸感和内容的表达效果。然而&#xff0c;不少时候&#xff0c;我们可能会遇到视频声音过小的情况&#xff0c;这可能是由于录制时环境噪音干扰、设备收音不佳…

学懂C++ (二十一):高级教程——深入C++多线程开发详解

C多线程开发详解 多线程编程是现代应用程序开发中不可或缺的一部分。C11引入了对多线程的支持&#xff0c;使得程序员能够更方便地利用多核处理器&#xff0c;提高程序的性能和响应能力。本文将全面而深入地探讨C的多线程相关概念&#xff0c;包括线程的创建与管理、互斥量…

Android Fragment:详解,结合真实开发场景Navigation

目录 1&#xff09;Fragment是什么 2&#xff09;Fragment的应用场景 3&#xff09;为什么使用Fragment? 4&#xff09;Fragment如何使用 5&#xff09;Fragment的生命周期 6&#xff09;Android开发&#xff0c;建议是多个activity&#xff0c;还是activity结合fragment&…

免费【2024】springboot 二手图书交易系统的设计与实现

博主介绍&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围&#xff1a;SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…

Llama 3.1用了1.6万个英伟达H100 GPU,耗费......

目录 Llama 3.1发布简介 Llama 3.1模型规模与训练 大模型企业发展面临的问题与困境 算力和能耗算力方面 数据和资金方面 技术和人才方面 Llama 3.1发布简介 当地时间 2024年 7月 23号&#xff0c;Meta 公司发布了迄今为止最强大的开源 AI 模型 Llama 3.1。该模型不仅规模…

Java二十三种设计模式-享元模式(12/23)

享元模式&#xff1a;高效管理大量对象的设计模式 引言 在软件开发中&#xff0c;有时需要处理大量相似或重复的对象&#xff0c;这可能导致内存使用效率低下和性能问题。享元模式提供了一种解决方案&#xff0c;通过共享对象的共同部分来减少内存占用。 基础知识&#xff0c…

谷粒商城实战笔记-145-性能压测-性能监控-jvisualvm使用-解决插件不能安装

文章目录 jvisualvm的作用安装查看gc相关信息的插件解决jvisualvm不能正常安装插件的问题1&#xff0c;查看java版本2&#xff0c;打开网址3&#xff0c;修改jvisualvm的设置 jvisualvm的作用 JVisualVM是一个集成在Java Development Kit (JDK) 中的多功能工具&#xff0c;它提…

LLMOps — 使用 BentoML 为 Llama-3 模型提供服务

使用 BentoML 和 Runpod 快速设置 LLM API 经常看到数据科学家对 LLM 的开发感兴趣&#xff0c;包括模型架构、训练技术或数据收集。然而&#xff0c;我注意到&#xff0c;很多时候&#xff0c;除了理论方面&#xff0c;许多人在以用户实际使用的方式提供这些模型时遇到了问题…

【C++】—— 类与对象(三)

【C】—— 类与对象&#xff08;三&#xff09; 4、拷贝构造函数4.1、初识拷贝构造4.1.1、为什么要传引用4.1.2、引用尽量加上 const 4.2、深入拷贝构造4.2.1、为什么要自己实现拷贝构造4.2.2、传值返回先调用拷贝构造的原因4.2.3、躺赢的 MyQueue4.2.4、传值返回与引用返回 4.…