0

0

c++中如何使用std::list的sort成员函数_c++链表排序方法【实例】

冰火之心

冰火之心

发布时间:2026-01-20 15:19:16

|

556人浏览过

|

来源于php中文网

原创

std::list::sort只能对自身原地排序,不接受迭代器范围,也不支持其他容器;它是稳定归并排序,时间复杂度O(N log N),要求比较器满足严格弱序且不可修改元素。

c++中如何使用std::list的sort成员函数_c++链表排序方法【实例】

std::list::sort 只能对 list 自身排序,不能传入 vector 或其他容器

std::list 的 sort() 是成员函数,不是算法函数,它只能对当前 std::list 实例原地排序,不接受迭代器范围(比如 begin(), end()),也不支持对 std::vectorstd::deque 调用。误以为它是 std::sort 的替代写法,是常见误解。

  • std::list::sort() 无参数时按 operator 升序排列
  • 可传入自定义比较器,类型必须满足 Compare const&,且不能是 lambda 捕获变量(除非用 std::function 包装或定义为 static/全局)
  • 不能对空 list 或只含一个元素的 list 调用出错,但也没必要——它本身是安全的

自定义比较函数必须满足严格弱序,且不能修改元素

传给 sort() 的比较器如果违反严格弱序(比如返回 a ),行为未定义;若在比较过程中修改了被比较对象(例如通过引用修改值),可能导致迭代器失效或无限循环。

  • 推荐使用普通函数指针或无捕获 lambda(C++17 起允许无捕获 lambda 作为模板参数)
  • 有状态比较需用仿函数类,确保 const operator() 且不改变成员变量语义
  • 避免在比较器中做耗时操作(如 IO、内存分配),list::sort() 是归并排序,比较次数约 O(N log N)

与 std::sort 算法的关键区别:稳定、不依赖随机访问

std::list::sort() 是稳定排序,相同元素相对顺序不变;它不依赖迭代器的随机访问能力,仅需双向迭代器,因此比 std::sort(要求随机访问迭代器)更适合链表结构。但代价是无法像 std::sort 那样用 std::execution::par 并行化。

Playground AI
Playground AI

AI图片生成和修图

下载
  • std::list::sort() 时间复杂度是 O(N log N),空间复杂度 O(log N)(递归深度)
  • 若已用 std::vector 存数据,别为了排序转成 list 再调用 sort()——拷贝开销远大于 std::sort 原地排序收益
  • 插入频繁 + 偶尔排序 → list::sort() 合理;纯排序场景 → vector + std::sort 更快

完整可运行示例:升序、降序、按成员排序

#include 
#include 

struct Person {
    std::string name;
    int age;
};

int main() {
    std::list people = {{"Alice", 30}, {"Bob", 25}, {"Charlie", 35}};

    // 升序:按 age
    people.sort([](const Person& a, const Person& b) { return a.age < b.age; });

    // 降序:注意不能写 a.age > b.age 直接替换,要保持严格弱序逻辑清晰
    people.sort([](const Person& a, const Person& b) { return a.age > b.age; });

    // 按 name 字典序(需包含 )
    people.sort([](const Person& a, const Person& b) { return a.name < b.name; });

    for (const auto& p : people) {
        std::cout << p.name << "(" << p.age << ") ";
    }
    // 输出类似:Alice(30) Bob(25) Charlie(35)(取决于最后一次 sort)
}

注意:多次调用 sort() 会覆盖前一次顺序;若需保留原始顺序,应先 assign 或构造新 list。

立即学习C++免费学习笔记(深入)”;

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

525

2023.09.20

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

204

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

49

2026.01.05

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

479

2023.08.04

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号