C++学习笔记(三十六)——STL之排序算法

news2025/4/28 13:01:20

一、STL 算法

C++的STL(Standard Template Library) 提供了一组高效、通用的算法,这些算法适用于各种容器(如 vectorlistsetmap)。
这些算法主要位于 <algorithm><numeric> 头文件中。

  • 通用性:适用于所有 STL 容器,如 vectorlistdeque 等。
  • 高效性:内部使用优化算法(如快速排序 std::sort)。
  • 一致性:所有算法都基于迭代器操作,使其与不同容器兼容。
  • 可组合性:可结合 lambda 表达式、bindfunction object 使用。

二、STL 算法分类

STL 算法可分为以下几类:

类别常见算法作用
排序sortstable_sortpartial_sortnth_element排序
搜索findfind_ifcountcount_ifbinary_search查找元素
修改copyreplacereplace_ifswapfill修改容器内容
删除removeremove_ifunique删除元素
归约for_eachaccumulate处理数据
合并mergeset_unionset_intersection处理有序序列
排列组合next_permutationprev_permutation生成排列
堆操作push_heappop_heapmake_heapsort_heap处理堆

三、STL 排序算法

STL 提供了一些常用的排序算法,用于对容器中的元素进行排序。
它们位于 <algorithm> 头文件中。

算法名称功能描述时间复杂度空间复杂度使用场景
sort对容器元素进行排序(默认升序)O(n log n)O(log n)适合一般排序,且不关心相等元素顺序
stable_sort保证相等元素的顺序不变O(n log n)O(n)适合需要稳定排序的场景,如多次排序
partial_sort仅对前 n 个元素排序O(n log k)O(n)只需要排序最小的 n 个元素
nth_element对第 n 小元素进行排序,且两侧有序O(n)O(1)寻找第 n 小元素,适合大数据情况
reverse反转容器元素的顺序O(n)O(1)用于反转容器,常与排序结合使用

(1) sort

  • 功能:对容器中的元素进行排序,默认按升序排序。
  • 时间复杂度O(n log n)(平均和最坏情况)。
  • 空间复杂度O(log n)(递归调用栈空间)。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

int main() {
    vector<int> vec = {5, 2, 8, 3, 1};

    sort(vec.begin(), vec.end());

    for (int i : vec) 
    {
        std::cout << i << " ";  // 输出:1 2 3 5 8
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • sort是最常用的排序算法,排序速度较快,但不能保证相等元素的顺序不变

(2) stable_sort

  • 功能:与 sort 相似,但保证相等元素的相对顺序不变
  • 时间复杂度O(n log n)(与 sort 相同)。
  • 空间复杂度O(n)(通常需要额外空间用于稳定性保证)。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

int main() {
    vector<int> vec = { 5, 2, 8, 3, 5 };

    stable_sort(vec.begin(), vec.end());

    for (int i : vec) 
    {
        cout << i << " ";  // 输出:2 3 5 5 8
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • stable_sort适用于需要保留相等元素顺序的场景,如按照多个条件排序时。

(3)partial_sort

  • 功能:对容器中的前 n 个元素进行排序,使它们排好序,其他元素保持原顺序。
  • 时间复杂度O(n log k),其中 n 是需要排序的元素数目,k 容器中的元素总数。
  • 空间复杂度O(n)
  • 说明:适用于只需要获取最小(或最大)n 个元素的情况。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

int main() {
    vector<int> vec = { 5, 2, 8, 3, 1 };

    // 排序前3个元素
    partial_sort(vec.begin(), vec.begin() + 3, vec.end());

    for (int i : vec) 
    {
        cout << i << " ";  // 输出:1 2 3 8 5
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • partial_sort适用于只需要获取最小(或最大)n 个元素的情况。

(4)nth_element

  • 功能:将容器中的元素按照第 n 小元素排列,使得n 小元素的左边小于等于它,右边大于等于它
  • 时间复杂度O(n),即线性时间复杂度。
  • 空间复杂度O(1)

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

int main() {
    vector<int> vec = { 5, 2, 8, 3, 1 };

    // 将第3小的元素放到第3位置,且两侧元素满足排序条件
    nth_element(vec.begin(), vec.begin() + 2, vec.end());

    for (int i : vec) 
    {
        cout << i << " ";  // 输出:1 2 3 5 8
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • nth_element通常用于找到容器中的第 n 小(或大)元素,不需要完全排序。

(5)reverse

  • 功能:反转容器中元素的顺序。
  • 时间复杂度O(n)n 是容器中的元素数目。
  • 空间复杂度O(1),原地操作。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

int main() {
    vector<int> vec = { 1, 2, 3, 4, 5 };

    // 反转数组
    reverse(vec.begin(), vec.end());

    for (int i : vec) 
    {
        cout << i << " ";  // 输出:5 4 3 2 1
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • reverse用于反转容器中的元素,常用于从降序排序转换为升序排序。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AI图像编辑器 Luminar Neo 便携版 Win1.24.0.14794

如果你对图像编辑有兴趣&#xff0c;但又不想花费太多时间学习复杂的软件操作&#xff0c;那么 Luminar Neo 可能就是你要找的完美工具。作为一款基于AI技术的创意图像编辑器&#xff0c;Luminar Neo简化了复杂的编辑流程&#xff0c;即使是没有任何图像处理经验的新手&#xf…

发币流程是什么,需要多少成本?

这是一个专注于Web3相关开发的账号&#xff0c;具体会讲解步骤以及开发方案 偶尔会有科普&#xff0c;有兴趣的可以点右上角关注一下 发币&#xff08;发行数字货币&#xff09;的流程通常涉及技术实现、法律合规、经济模型设计等多个环节&#xff0c;以下是关键步骤的简要说明…

【fork初体验】

文章目录 Linux 实验&#xff1a;深入理解 fork 系统调用一、实验目的二、实验环境三、实验内容与步骤&#xff08;一&#xff09;打印进程的进程 ID 和父进程 ID1. 编写程序2. 编译与运行3. 运行结果 &#xff08;二&#xff09;使用 fork 系统调用创建进程并加入循环语句1. 编…

学习设计模式《六》——抽象工厂方法模式

一、基础概念 抽象工厂模式的本质是【选择产品簇(系列)的实现】&#xff1b; 抽象工厂模式定义&#xff1a;提供一个创建一系列相关或相互依赖对象的接口&#xff0c;而无需指定它们具体的类&#xff1b; 抽象工厂模式功能&#xff1a;抽象工厂的功能是为一系列相关对象或相互依…

python_BeautifulSoup提取html中的信息

目录 描述&#xff1a; 过程&#xff1a; step one 下载html网页到本地 step two 提取html信息 list_con soup.select(.list-con) [0] li_list list_con.find_all(li) a li.find(span).find(a) title a.get(title) url a.get(href) span li.find(span).find(spa…

今日头条如何查看IP归属地?详细教程与常见问题解答

在当今互联网时代&#xff0c;IP属地信息已成为各大社交平台展示用户真实性的重要标识。今日头条作为国内领先的资讯平台&#xff0c;也提供了IP属地显示功能。那么&#xff0c;今日头条怎么查看IP归属地&#xff1f;本文将详细介绍在今日头条11.9.0版本中如何查看自己和他人的…

【物联网】基于LORA组网的远程环境监测系统设计(机智云版)

基于LORA组网的远程环境监测系统设计(机智云版) 演示视频: 简介: 1.本系统有一个主机,两个从机。 2.一主多从的LORA组网通信,主机和两个从机都配备了STM32F103单片机与 LoRa 模块,主机作为中心设备及WIFI网关,负责接收和发送数据到远程物联网平台和手机APP,两个从机…

制作一款打飞机游戏22:表格导出

编辑器功能扩展 今天&#xff0c;我想让编辑器能够处理一个数组&#xff0c;这是编辑器将要编辑的东西&#xff0c;它只编辑数组。这些区域在后续的不同版本的编辑器中会有不同的含义&#xff0c;但现在我想创建一个模板&#xff0c;能够加载一个二维数组&#xff0c;并将二维…

Linux内核源码结构

目录 Linux内核源码结构 Linux内核版本命名 Linux内核版本选择 内核源码结构 arch&#xff1a;与CPU架构相关的源代码 block:磁盘设备的支持 COPYING文件 CREDITS文件 crypto:加密相关 Documentation: drivers:设备驱动 firmware:固件 fs:文件系统 include:头文件…

72.评论日记

【巫师】中美关税战02&#xff1a;应给人民爆装备&#xff0c;以及普通人如何应对(7条建议)_哔哩哔哩_bilibili 2025年4月26日11:03:31

Websocket自动发送消息客户端工具

点击下载《Websocket自动发送消息客户端工具》 1. 前言 在现代网络应用中&#xff0c;实时通信和即时数据传输变得越来越重要。WebSocket作为一种全双工通信协议&#xff0c;因其高效、实时的特点&#xff0c;被广泛应用于聊天应用、实时数据监控、在线游戏等领域。然而&…

STM32的开发环境介绍

目录 STM32软件环境 Keil软件在线安装 其他软件环境安装 STM32开发的几种方式 STM32寄存器版本和库函数版本 标准外设库的作用&#xff1a; STM32软件环境 STM32 的集成开发环境&#xff08;IDE&#xff09;&#xff1a;编辑编译软件 常见的环境&#xff1a; (1)KEIL&a…

数据库系统概论(四)关系操作,关系完整性与关系代数

数据库系统概论&#xff08;四&#xff09;详细讲解关系操作&#xff0c;关系完整性与关系代数 前言一、什么是关系操作1.1 基本的关系操作1.2 关系数据语言的分类有哪些 二、关系的完整性2.1 实体完整性2.2 参照完整性2.3 用户的定义完整性 三、关系代数是什么3.1 传统的集合运…

基于 IPMI + Kickstart + Jenkins 的 OS 自动化安装

Author&#xff1a;Arsen Date&#xff1a;2025/04/26 目录 环境要求实现步骤自定义 ISO安装 ipmitool安装 NFS定义 ks.cfg安装 HTTP编写 Pipeline 功能验证 环境要求 目标服务器支持 IPMI / Redfish 远程管理&#xff08;如 DELL iDRAC、HPE iLO、华为 iBMC&#xff09;&…

使用 Node、Express 和 MongoDB 构建一个项目工程

本文将详细介绍如何使用 Node.js Express MongoDB 构建一个完整的 RESTful API 后端项目&#xff0c;涵盖&#xff1a; 项目初始化 Express 服务器搭建 MongoDB 数据库连接 REST API 设计&#xff08;CRUD 操作&#xff09; 错误处理与中间件 源码结构与完整代码 部署建…

【C++11】右值引用和移动语义:万字总结

&#x1f4dd;前言&#xff1a; 这篇文章我们来讲讲右值引用和移动语义 &#x1f3ac;个人简介&#xff1a;努力学习ing &#x1f4cb;个人专栏&#xff1a;C学习笔记 &#x1f380;CSDN主页 愚润求学 &#x1f304;其他专栏&#xff1a;C语言入门基础&#xff0c;python入门基…

Python基于Django的全国二手房可视化分析系统【附源码】

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…

VulnHub-DC-2靶机渗透教程

VulnHub-DC-2靶机渗透教程 1.靶机部署 [Onepanda] Mik1ysomething 靶机下载&#xff1a;https://download.vulnhub.com/dc/DC-2.zip 直接使用VMware导入打开就行 2.信息收集 2.1 获取靶机ip(arp-scan/nmap) arp-scan -l ​ nmap 192.168.135.0/24 2.2 详细信息扫描(nmap)…

n8n 中文系列教程_10. 解析n8n中的AI节点:从基础使用到高级Agent开发

在自动化工作流中集成AI能力已成为提升效率的关键。n8n通过内置的LangChain节点&#xff0c;让开发者无需复杂代码即可快速接入GPT-4、Claude等大模型&#xff0c;实现文本处理、智能决策等高级功能。本文将深入解析n8n的AI节点体系&#xff0c;从基础的Basic LLM Chain到强大的…

计算机网络 | 应用层(1)--应用层协议原理

&#x1f493;个人主页&#xff1a;mooridy &#x1f493;专栏地址&#xff1a;《计算机网络&#xff1a;自定向下方法》 大纲式阅读笔记 关注我&#x1f339;&#xff0c;和我一起学习更多计算机的知识 &#x1f51d;&#x1f51d;&#x1f51d; 目录 1. 应用层协议原理 1.1 …