快速选择算法 C++ 标准库函数:nth_element

👨‍💻 关于作者:会编程的土豆

"不是因为看见希望才坚持,而是坚持了才看见希望。"

你好,我是会编程的土豆,一名热爱后端技术的Java学习者。

📚 正在更新中的专栏:

💕作者简介:后端学习者

先看例题:

cpp 复制代码
class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        nth_element(nums.begin(), nums.end() - k, nums.end());
        return nums[nums.size() - k];
    }
};

对,就是这么简单,完了,而且速度极快,时间复杂度为O(n);

下面仔细阐述一下这个库函数:

nth"n-th" 的缩写,意思是 "第 n 个"

拆解

  • n:表示一个整数序号

  • th:英语序数词后缀(如 4th, 5th, 6th)

  • 合起来 n-th:第 n 个

在函数名中的含义

std::nth_element 直译就是 "第 n 个元素"

它的作用是:把容器中如果完全排序后,应该排在第 n 个位置的那个元素 放到第 n 个位置。

下标从0开始的哦

作用把第二个参数表示的那个位置 "应该排在那个位置的元素"放过去,且不保证其他元素有序

cpp 复制代码
nth_element(nums.begin(), nums.end() - k, nums.end());
//           ↑             ↑                 ↑
//         起始迭代器    目标位置迭代器      结束迭代器
  • nums.end() - k 就是倒数第 k 个位置

  • 因为是升序排序,倒数第 k 个位置就是第 k 大的元素所在的位置

举例

数组 [3,2,1,5,6,4],k = 2:

  • 完全排序后是 [1,2,3,4,5,6]

  • 第 2 大是 5,在倒数第 2 个位置(下标 4)

  • nth_element 后数组变成类似 [3,2,1,4,5,6](不唯一)

  • 下标 4 的元素必定是 5

复杂度

维度 复杂度
时间 平均 O(n),最坏 O(n²)(但标准库通常用 Introselect 保证 O(n))
空间 O(1)

其他语言的类似函数

语言 等价函数
C++ std::nth_element
Python heapq.nlargest(k, nums)[-1]sorted(nums)[-k]
Java Arrays.sort(nums); return nums[nums.length - k];
相关推荐
八解毒剂几秒前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
会Tk矩阵群控的小木5 分钟前
基于Python的iMessage短信群发与社媒多账号统一管理系统实现
开发语言·windows·python·新媒体运营·开源软件·个人开发
我是一颗柠檬8 分钟前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
wu_ye_m10 分钟前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习
njsgcs17 分钟前
c# solidworks 创建装配体工程图+bom
开发语言·c#·solidworks
运行时记录23 分钟前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
起床困难户57530 分钟前
条款20:协助完成返回值优化
c++
啦啦啦啦啦zzzz36 分钟前
算法总结(二分查找、双指针)
c++·算法
小林敲代码778836 分钟前
记录一下IDEA中很多变量变色的方案
java·开发语言·spring boot·idea
njsgcs1 小时前
c# solidworks 工程图获得展开视图不在固定面螺纹特征的位置
开发语言·c#·solidworks