首页 > 后端开发 > C++ > 正文

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

P粉602998670
发布: 2025-08-29 08:19:01
原创
751人浏览过
使用STL的sort函数可高效排序数组或容器,需包含<algorithm>头文件,通过传入起始和结束迭代器实现升序或降序排序,支持自定义比较函数或lambda表达式,适用于C风格数组、vector等容器及结构体对象,显著提升编码效率。

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

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

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

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

示例:

#include <algorithm>
#include <iostream>
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++免费学习笔记(深入)”;

例如,实现降序排序:

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人
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 <vector>
#include <algorithm>
using namespace std;

vector<int> vec = {3, 7, 2, 5};
sort(vec.begin(), vec.end());  // 升序
登录后复制

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

struct Student {
    string name;
    int score;
};

vector<Student> 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函数应用的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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