C++数组排序算法 STL sort函数应用

使用STL的sort函数可高效排序数组或容器,需包含头文件,通过传入起始和结束迭代器实现升序或降序排序,支持自定义比较函数或lambda表达式,适用于C风格数组、vector等容器及结构体对象,显著提升编码效率。

c++数组排序算法 stl sort函数应用

在C++中,对数组进行排序最常用且高效的方法是使用STL中的sort函数。它位于gorithm>头文件中,能够快速对普通数组或容器进行升序或降序排序,无需手动实现复杂的排序逻辑。

基本用法:对普通数组排序

对于C风格的数组,sort函数通过传入起始和结束地址来工作。注意结束地址是“末尾后一位”,即使用指针表示时为arr + n。

示例:

#include #include using namespace std;int main() {    int arr[] = {5, 2, 8, 1, 9};    int n = sizeof(arr) / sizeof(arr[0]);    sort(arr, arr + n);  // 升序排序    for (int i = 0; i < n; ++i) {        cout << arr[i] << " ";    }    // 输出:1 2 5 8 9    return 0;}

自定义排序规则:降序或特定条件

可以通过传入第三个参数——比较函数,来自定义排序顺序。比较函数返回bool值,表示第一个参数是否应排在第二个之前。

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

例如,实现降序排序:

bool cmp(int a, int b) {    return a > b;  // a排在b前面的条件}sort(arr, arr + n, cmp);

也可以使用lambda表达式,更简洁:

sort(arr, arr + n, [](int a, int b) {    return a > b;});

对容器如vector排序

sort函数同样适用于STL容器,如vector、deque等。

#include #include using namespace std;vector vec = {3, 7, 2, 5};sort(vec.begin(), vec.end());  // 升序

对结构体或类对象排序时,可通过比较函数按指定字段排序:

struct Student {    string name;    int score;};vector students = {{"Alice", 85}, {"Bob", 90}, {"Cindy", 80}};sort(students.begin(), students.end(), [](const Student& a, const Student& b) {    return a.score > b.score;  // 按分数降序});

基本上就这些。熟练使用sort函数能大幅提高编码效率,避免手写冒泡或快排。关键是记住传参格式和比较函数的逻辑方向。不复杂但容易忽略细节。

以上就是C++数组排序算法 STL sort函数应用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1473429.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 20:27:27
下一篇 2025年12月18日 20:27:34

相关推荐

  • C++医疗设备开发环境怎么搭建 IEC 62304合规工具链

    搭建符合IEC 62304标准的C++医疗设备开发环境,需选择经安全认证的编译器(如Green Hills、IAR)、集成静态分析工具(如Coverity、Klocwork)以检测代码缺陷并支持MISRA C++规范,采用单元测试框架(如Google Test、Catch2)实现需求覆盖与代码可靠性…

    2025年12月18日
    000
  • C++ deque容器原理 双端队列数据结构

    deque在两端高效插入删除且支持随机访问,适用于需频繁首尾操作并索引访问的场景,其通过分块存储和指针地图实现O(1)首尾增删与O(1)随机访问,相比vector避免了前端移动开销,相比list保留了索引能力,但需注意缓存局部性差、内存开销大及中间操作导致迭代器失效等问题,最佳实践是明确需求、避免中…

    2025年12月18日
    000
  • C++井字棋游戏编写 二维数组胜负判断逻辑

    答案是char checkWinner函数通过检查行、列和对角线判断胜负,若三子相同且非空则返回对应玩家符号。 在C++中实现井字棋(Tic-Tac-Toe)游戏时,胜负判断是核心逻辑之一。通常使用3×3的二维数组表示棋盘,玩家轮流下子,通过判断行、列或对角线是否达成三子连线来决定胜负。 …

    2025年12月18日
    000
  • C++智能指针原理 RAII资源管理机制

    智能指针基于RAII机制,通过对象构造获取资源、析构释放资源,确保内存自动管理。std::unique_ptr独占资源,std::shared_ptr共享资源并引用计数,std::weak_ptr解决循环引用,三者均绑定资源生命周期到对象生命周期,异常安全且防泄漏。 智能指针的核心在于自动管理动态分…

    2025年12月18日
    000
  • C++联合体联合类型 类型安全访问方法

    C++联合体不安全因无类型标签,易致未定义行为;通过手动封装类型标签或使用std::variant可实现安全访问,后者兼具编译时检查与自动资源管理,是现代C++推荐方案。 C++联合体,或者我们常说的 union ,它在内存优化上确实独树一帜,但要说类型安全,那它可真是个“野孩子”。直接使用 uni…

    2025年12月18日
    000
  • C++备忘录模式 对象状态保存恢复

    备忘录模式通过发起者、备忘录和管理者三者协作,实现对象状态的保存与恢复。发起者负责创建和恢复状态,备忘录存储状态且对外只读,管理者保存多个备忘录以支持撤销操作。示例中Editor为发起者,Memento保存文本状态,History用栈管理备忘录,实现撤销功能。该模式保持封装性,适用于实现撤销、快照等…

    2025年12月18日
    000
  • 怎样测试C++异常处理代码 单元测试框架中的异常测试方法

    要测试c++++异常处理代码,核心在于使用单元测试框架提供的宏来验证代码是否按预期抛出或不抛出特定类型的异常。1. 使用如google test的assert_throw和expect_throw来检查指定代码是否抛出期望的异常类型;2. 用assert_any_throw和expect_any_t…

    2025年12月18日 好文分享
    000
  • C++拷贝控制成员 三五法则实现原则

    三五法则指出,若类需自定义析构函数、拷贝构造、拷贝赋值、移动构造或移动赋值中的任一函数,通常需显式定义全部五个,以正确管理资源。默认合成函数执行浅拷贝,导致资源重复释放或泄漏,故需手动实现深拷贝或移动语义。现代C++推荐使用Rule of Zero,即依赖智能指针和标准容器自动管理资源,避免手动定义…

    2025年12月18日
    000
  • C++匿名联合体应用 特殊内存访问场景

    匿名联合体允许同一内存被不同类型的成员共享,直接通过外层结构体访问,适用于类型双关、硬件寄存器映射和内存优化;但易引发未定义行为,尤其在跨类型读写时,需谨慎使用volatile、避免严格别名违规,并优先采用memcpy或std::bit_cast等安全替代方案。 C++的匿名联合体,在我看来,是一把…

    2025年12月18日
    000
  • C++文件链接操作 软链接硬链接处理

    C++中处理文件链接主要通过std::filesystem(C++17起)或系统调用实现,软链接提供跨文件系统灵活引用,硬链接实现同文件系统内数据共享与高效多入口,二者分别适用于抽象路径、版本管理及节省空间等场景。 C++中处理文件链接,主要是指通过操作系统提供的系统调用,在C++程序中创建、读取或…

    2025年12月18日
    000
  • C++锁管理异常 自动解锁保障机制

    使用RAII机制可防止C++异常导致死锁:std::lock_guard和std::unique_lock在析构时自动释放锁,确保异常安全;应缩短持锁时间、避免在锁内调用回调、按固定顺序加锁,并用std::scoped_lock管理多锁,保证系统稳定。 C++中使用锁时,若未正确管理,容易因异常导致…

    2025年12月18日
    000
  • C++ list容器特性 双向链表实现原理

    c++kquote>std::list是双向链表,支持O(1)任意位置插入删除,但随机访问为O(n),内存开销大且缓存不友好;相比vector和deque,它适合频繁中间修改、迭代器稳定的场景,但遍历和访问效率低,需权衡使用。 std::list 在C++标准库中,是一个非常独特且功能强大的容…

    2025年12月18日
    000
  • C++标记模式 运行时类型识别替代

    标记模式是一种基于类型标签在编译期实现函数分发的技术,通过定义标签类型(如tag_derived_a)并结合虚函数返回对应标签,利用if constexpr在编译期判断类型并调用相应逻辑,避免了RTTI开销,适用于嵌入式或性能敏感场景,但需手动扩展标签且灵活性低于dynamic_cast。 在C++…

    2025年12月18日
    000
  • C++结构体数组操作 批量数据处理技巧

    C++结构体数组通过连续内存布局实现高效批量数据处理,其核心优势在于数据局部性和缓存友好性。定义结构体时应注重成员精简与内存对齐,推荐使用std::vector并预分配内存以减少开销。批量操作优先采用范围for循环或标准库算法如std::for_each、std::transform和std::re…

    2025年12月18日
    000
  • C++智能指针原理 RAII资源管理机制解析

    智能指针通过RAII机制实现内存自动管理,利用对象生命周期控制资源;std::unique_ptr独占所有权,std::shared_ptr引用计数共享资源,std::weak_ptr打破循环引用,三者均在析构时释放内存,避免泄漏。 智能指针的核心在于自动管理动态分配的内存,避免内存泄漏和悬空指针。…

    2025年12月18日
    000
  • 怎样配置C++的云原生调试环境 K8s容器内调试工具链

    在kubernetes容器内调试c++++应用的核心方法是通过远程调试,具体是将gdb或lldb集成到容器镜像中,使用kubectl port-forward将容器内调试端口映射到本地,并在vs code中配置launch.json实现远程附加调试,整个过程需确保编译时包含-g选项生成调试符号、正确…

    好文分享 2025年12月18日
    000
  • C++结构体默认构造 POD类型特性分析

    C++结构体在未显式定义构造函数时会自动生成默认构造函数,其行为取决于成员类型是否为POD类型;若所有成员均为POD类型,则默认构造函数不进行初始化,成员值为未定义,如包含非POD成员则调用其默认构造函数初始化,引用成员需显式初始化,POD类型具有平凡性、标准布局和可复制性,支持高效内存操作和C兼容…

    2025年12月18日
    000
  • C++异常安全总结 最佳实践综合指南

    异常安全通过RAII和复制再交换等技术保障程序在异常下的正确性。1. 基本保证确保资源不泄漏,对象状态有效;2. 强保证实现操作的原子性,典型方法是复制再交换;3. 无异常保证要求关键操作如析构函数和swap不抛出异常。使用智能指针、锁包装器等RAII类可自动释放资源,避免泄漏。移动操作应尽量标记n…

    2025年12月18日
    000
  • C++文件操作最佳实践 性能与安全平衡

    答案:C++文件操作需权衡性能与安全,通过选择合适打开模式、避免缓冲区溢出、正确处理异常、使用内存映射提升性能,并严格验证文件路径,结合RAII等技术确保资源安全。 C++文件操作既要保证性能,又要兼顾安全,并非一蹴而就,而是在实践中不断摸索和权衡的结果。最佳实践不是一套固定的规则,而是一种思维方式…

    2025年12月18日
    000
  • C++文件权限设置 跨平台权限控制方法

    C++17的std::filesystem通过统一接口简化跨平台文件权限管理,底层自动映射chmod或Windows API,支持权限枚举与组合,减少条件编译,提升代码可读性与可维护性。 C++在文件权限设置和跨平台权限控制方面,并没有一个统一的、原生的抽象层。本质上,我们处理的是操作系统层面的权限…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信