蓝桥杯---快速排序(leetcode第159题)最小的k个元素(剑指offer原题)

文章目录

1.题目概述

这个题目只是被包装了一下,本质上依然是使用的我们的快速排序算法,为什么这样说呢?因为仔细阅读题目你就会发现,这个需要我们去找到最小的前K个元素,并且进行返回值处理;

对于上面用到的几个实例,实际上cnt=1的时候,就是从这个给定的数组里面选择最小的前一个元素,也就是最小的元素;cnt=2的时候,也就是从我们的这个数组里面选择最小的两个元素;

上面的这些问题其实都不难理解,但是第一步我们需要做的就是去对于这个给定的数组进行排序,然后根据这个排序之后的结果进行选择我们的最小的K个元素

2.思路分析

其实这个整体的思路和之前的压根就没有区别,主要就是我们的这个进行数组分三块之后,是从左边开始找的,之前的(也就是昨天的那个文章)里面的题目是从右边开始找的,因为之前的那个是topk问题,也就是最大的k个元素,但是我们的这个里面是最小的,所以是从左边开始找的,但是这个整体的思路没变,还是去分别计算每一块里面的数据个数,和我们的k进行比较去,最后确定这个返回值;

3.代码详解

  • 首先,要看懂主要的那个函数里面写的代码,就是首先进行排序,排序之后,得到的这个数组是一个有顺序的,因此这个时候就是直接取出来这个排序之后的数组里面的前面的k个元素即可;

  • 然后就是常规的操作,选择基准元素,数组分三块,分类讨论,只不过这个里面的分类讨论我们是从左边开始的,因为这个题目要求的找到最小的k个元素;

  • 稍微解释一下,为什么这个a+b>=k的时候,我们没有进行任何的操作,就是因为这个时候我们的第二块里面的所有的元素数值都是一样的,都是key,因此这个里面我们不需要对于这个数组进行任何的操作;

相关推荐
Python×CATIA工业智造18 分钟前
详细页智能解析算法:洞悉海量页面数据的核心技术
爬虫·算法·pycharm
Swift社区21 分钟前
Swift 解 LeetCode 321:拼接两个数组中的最大数,贪心 + 合并全解析
开发语言·leetcode·swift
无聊的小坏坏1 小时前
力扣 239 题:滑动窗口最大值的两种高效解法
c++·算法·leetcode
黎明smaly1 小时前
【排序】插入排序
c语言·开发语言·数据结构·c++·算法·排序算法
YuTaoShao1 小时前
【LeetCode 热题 100】206. 反转链表——(解法一)值翻转
算法·leetcode·链表
YuTaoShao2 小时前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
CCF_NOI.2 小时前
(普及−)B3629 吃冰棍——二分/模拟
数据结构·c++·算法
运器1232 小时前
【一起来学AI大模型】支持向量机(SVM):核心算法深度解析
大数据·人工智能·算法·机器学习·支持向量机·ai·ai编程
Zedthm3 小时前
LeetCode1004. 最大连续1的个数 III
java·算法·leetcode
神的孩子都在歌唱3 小时前
3423. 循环数组中相邻元素的最大差值 — day97
java·数据结构·算法