C++ 中常用的排序函数介绍及示例代码
🔍在 C++ 中,有多种方式可以实现排序,标准库提供了一些非常实用的排序函数,下面为你介绍常用的几种: ### 1. `std::sort` 函数 `std::sort` 是 C++ 标准库 `<algorithm>` 头文件中提供的一个非常强大且常用的排序函数,它使用的是一种优化过的快速排序算法,平均时间复杂度为 $O(n log n)$。 **示例代码**: ```cpp #include <iostream> #include <algorithm> #include <vector> int main() { std::vector<int> numbers = {5, 2, 9, 1, 5, 6}; // 使用 std::sort 对向量进行排序 std::sort(numbers.begin(), numbers.end()); // 输出排序后的结果 for (int num : numbers) { std::cout << num << " "; } std::cout << std::endl; return 0; } ``` **代码解释**: - 首先包含必要的头文件 `<iostream>`、`<algorithm>` 和 `<vector>`。 - 定义一个 `std::vector<int>` 类型的向量 `numbers` 并初始化。 - 调用 `std::sort` 函数,传入向量的起始迭代器 `numbers.begin()` 和结束迭代器 `numbers.end()`,对向量中的元素进行排序。 - 最后使用范围 for 循环输出排序后的元素。 ### 2. `std::stable_sort` 函数 `std::stable_sort` 同样在 `<algorithm>` 头文件中,它能保证相等元素的相对顺序在排序后保持不变,时间复杂度也是 $O(n log n)$。 **示例代码**: ```cpp #include <iostream> #include <algorithm> #include <vector> struct Person { int age; std::string name; }; bool compareByAge(const Person& a, const Person& b) { return a.age < b.age; } int main() { std::vector<Person> people = { {25, "Alice"}, {20, "Bob"}, {25, "Charlie"} }; // 使用 std::stable_sort 对向量进行排序 std::stable_sort(people.begin(), people.end(), compareByAge); // 输出排序后的结果 for (const auto& person : people) { std::cout << person.name << " (" << person.age << ") "; } std::cout << std::endl; return 0; } ``` **代码解释**: - 定义一个 `Person` 结构体,包含年龄和姓名两个成员。 - 定义一个比较函数 `compareByAge`,用于指定排序规则,这里按照年龄从小到大排序。 - 创建一个 `std::vector<Person>` 类型的向量 `people` 并初始化。 - 调用 `std::stable_sort` 函数,传入向量的起始迭代器、结束迭代器和比较函数,对向量中的元素进行排序。 - 最后使用范围 for 循环输出排序后的元素。 ### 3. `std::partial_sort` 函数 `std::partial_sort` 用于对序列的前 `n` 个元素进行排序,将最小(或最大)的 `n` 个元素放到序列的前面,其余元素的顺序未定义。 **示例代码**: ```cpp #include <iostream> #include <algorithm> #include <vector> int main() { std::vector<int> numbers = {5, 2, 9, 1, 5, 6}; int n = 3; // 使用 std::partial_sort 对前 n 个元素进行排序 std::partial_sort(numbers.begin(), numbers.begin() + n, numbers.end()); // 输出排序后的前 n 个元素 for (int i = 0; i < n; i++) { std::cout << numbers[i] << " "; } std::cout << std::endl; return 0; } ``` **代码解释**: - 定义一个 `std::vector<int>` 类型的向量 `numbers` 并初始化。 - 定义要排序的元素个数 `n`。 - 调用 `std::partial_sort` 函数,传入向量的起始迭代器、指向第 `n` 个元素的迭代器和结束迭代器,对前 `n` 个元素进行排序。 - 最后使用 for 循环输出排序后的前 `n` 个元素。 ######[AI问答 | 1062点数解答 | 2026-04-04 20:03:28]
- C 语言实现链表操作:创建、输出、删除及插入功能详解(字节豆包 | 534点数解答 | 2024-12-09 21:33:48)346
- C语言实现链表创建、输出、删除与插入操作的完整代码及注意要点(字节豆包 | 609点数解答 | 2024-12-18 12:18:21)366
- Java实现链表反转:迭代与递归双解法详解及开发实战指南(DeepSeek | 1409点数解答 | 2026-03-15 15:09:29)33
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)350
- 深入解析Java LinkedList中poll()与pop()方法的差异与使用场景(阿里通义 | 209点数解答 | 2024-01-13 18:17:28)451
- 探寻数组中最长摆动子序列长度:思路剖析与代码优化(GPT | 758点数解答 | 2024-12-23 23:18:29)274
- 独家剖析:求解数组最长摆动子序列长度的代码实现与改进建议(GPT | 350点数解答 | 2024-12-23 23:20:54)271
- 工程师必备:HTTP协议调试代理工具及抓取HTTPS协议详细设置过程(百度文心 | 352点数解答 | 2023-11-09 18:25:54)552
- 常用!编写 App 的原生与跨平台代码语言全揭秘(字节豆包 | 508点数解答 | 2025-10-18 19:11:58)56
- Three.js 示例代码解析:优化场景渲染与注意要点(字节豆包 | 164点数解答 | 2025-02-27 23:30:20)267
- C语言实现多班级学生信息管理系统:含增删改查与多样排序功能(GPT | 2547点数解答 | 2024-12-15 22:08:58)363
- C语言实现学生信息管理系统:含增删改查与多种排序功能(GPT | 6408点数解答 | 2024-12-15 22:10:03)353