新闻中心

C++如何自定义排序函数的规则_C++排序算法与比较器自定义示例

2025-11-06
浏览次数:
返回列表
C++中自定义排序通过std::sort配合比较函数、Lambda或重载

c++如何自定义排序函数的规则_c++排序算法与比较器自定义示例

在C++中,自定义排序规则主要通过std::sort配合比较函数或比较器实现。默认情况下,std::sort对基本类型按升序排列,但面对复杂数据类型或特殊排序需求时,就需要手动定义排序规则。

使用函数指针定义比较规则

最直接的方式是编写一个返回布尔值的比较函数,用于指定两个元素之间的“小于”关系。

例如,对整数数组进行降序排序:

#include <algorithm>
#include <vector>
#include <iostream>

bool descending(int a, int b) {
    return a > b;  // 当a大于b时,a应排在b前面
}

int main() {
    std::vector<int> nums = {5, 2, 8, 1, 9};
    std::sort(nums.begin(), nums.end(), descending);
    
    for (int n : nums) std::cout << n << " ";
    // 输出:9 8 5 2 1
}

使用Lambda表达式简化比较逻辑

C++11起支持Lambda,适合简单、局部使用的排序规则。

比如按绝对值大小排序:

std::vector<int> nums = {-3, 1, -7, 4, 0};
std::sort(nums.begin(), nums.end(), [](int a, int b) {
    return abs(a) < abs(b);  // 按绝对值升序
});
// 结果:0 1 -3 4 -7

对结构体或类自定义排序

当排序对象是自定义类型时,可通过函数对象(仿函数)或Lambda明确排序依据。

刺鸟创客 刺鸟创客

一款专业高效稳定的AI内容创作平台

刺鸟创客 110 查看详情 刺鸟创客

定义一个表示学生的信息结构体,按成绩降序、姓名升序排列:

struct Student {
    std::string name;
    int score;
};

std::vector<Student> students = {
    {"Alice", 85}, {"Bob", 90}, {"Charlie", 85}
};

std::sort(students.begin(), students.end(), [](const Student& a, const Student& b) {
    if (a.score == b.score)
        return a.name < b.name;   // 成绩相同时按姓名升序
    return a.score > b.score;     // 否则按成绩降序
});

此方法灵活控制多字段排序优先级。

重载操作符实现默认排序

若某类型经常需要排序,可在结构体内重载运算符,使<code>std::sort无需额外参数。

struct Point {
    int x, y;
    bool operator<(const Point& other) const {
        return x < other.x || (x == other.x && y < other.y);
    }
};

std::vector<Point> pts = {{2,3}, {1,5}, {2,1}};
std::sort(pts.begin(), pts.end()); // 使用默认比较
// 排序后:(1,5), (2,1), (2,3)

基本上就这些常见方式。函数指针适合复用逻辑,Lambda适合临时规则,重载适合类型内置顺序明确的情况。掌握这些方法,就能应对大多数排序场景。

以上就是C++如何自定义排序函数的规则_C++排序算法与比较器自定义示例的详细内容,更多请关注其它相关文章!


# 降序  # 出轨网站建设文案范例  # 文具网站建设理念  # 广东seo排名怎么引流  # 药店线上营销推广方案  # 露营项目营销推广策略  # 哈尔滨大型网站建设收费  # 肇庆推广营销方式  # 二手书的营销推广  # 浙江网站建设软件推广  # 兰山区网站优化报价公司  # 游戏开发  # 如何实现  # 多字  # c++  # 重写  # 数据结构  # 运算符  # 如何使用  # 升序  # 自定义  # 排列  # stream  # ios  # ai  # go  # 排序算法 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 消息称三星明年 2 月正式发布 HBM4,与 SK 海力士同台竞技  如何仅使用CSS更改登录界面背景图像图标的颜色  C++如何解决segmentation fault_C++段错误调试与原因分析  快手网页版在线登录 快手网页版官网入口快速访问  poki网页游戏推荐_poki免费游戏平台入口  Tabulator表格中精确实现日期时间排序的指南  C++20的source_location是什么_C++在编译期获取源码位置信息用于日志和断言  mcjs网页版流畅运行 mcjs低配电脑畅玩入口  微信网页版官方入口直达 微信网页版网页版登录使用方法  Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析  AI泡沫首次被“刺破”:GPU十年都无法存活!  Win10如何恢复误删的快捷方式_Win10重建常用软件快捷方式  J*aScript中高效管理与清空动态列表:避免循环陷阱  解决Bootstrap卡片顶部边距导致背景图下移的问题  在Go语言中利用后缀数组处理多字符串:实现高效文本匹配与自动补全  QQ邮箱网页版入口登录 QQ邮箱在线邮箱官方通道  qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决  电脑屏幕颜色不舒服怎么办_Windows夜间模式与色彩校准教程【护眼技巧】  俄罗斯Yandex免登录入口_Yandex搜索引擎官网一键直达  J*a递归快速排序中静态变量导致数据累积问题的解决方案  PrimeNG Sidebar背景色自定义指南:CSS覆盖与主题化实践  双系统安装时,如何设置默认启动系统? msconfig命令了解一下!  PostgreSQL海量数据高效导入策略:Python与Django实践指南  4399网页游戏电脑版全新入口 4399电脑端在线玩指南  Python多线程中正确使用sigwait处理SIGALRM信号  Selenium Python中处理点击后新窗口加载冻结问题的策略与实践  漫蛙官网正版漫画入口 漫蛙2官方网页登录地址  迅雷下载到U盘速度很慢怎么办_迅雷U盘下载慢优化方法  sublime如何只显示或隐藏特定类型文件_sublime侧边栏文件过滤  CSS布局中意外空白:解决padding-top导致的顶部间距问题  AO3官方镜像站点汇总 AO3同人作品网页版直达链接  Sublime Text怎么显示空格和制表符_Sublime显示不可见字符设置  c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架  sublime如何处理大型CSV文件的列对齐_sublime高级表格编辑插件指南  Win10文件资源管理器“此电脑”分组怎么关 Win10恢复经典视图【技巧】  css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容  海棠账号登录入口_登录海棠账户同步阅读记录  如何优雅地扩展SprykerGlue后端API授权逻辑,使用spryker/glue-backend-api-application-authorization-connector-extension  在J*a中如何捕获IndexOutOfBoundsException_索引越界异常防护方法说明  如何高效处理PHP中的Excel数据导入导出?PortPHP/Spreadsheet助你轻松搞定!  抖音创作助手登录入口_抖音创作辅助工具官网直达  高德地图公交到站提醒失败如何解决 高德提醒权限设置  Python实时数据流中的动态最值查找策略  如何解决电商平台定制报价请求的“黑洞”问题,SprykerQuoteRequest模块助你提升客户体验与销售效率  Lar*el DB::listen 事件中的查询执行时间单位解析  《明末:渊虚之羽》设计师谈设计角色:那会刚毕业 充满激情  网易大神怎么保存别人动态的图片_网易大神动态图片保存方法  一加Ace 6T实拍样张首次公布!李杰:主摄实力完全看齐4K档性能旗舰  Archive of Our Own官网直达 AO3最新可用地址一览  Sublime Text怎么设置垂直标尺_Sublime配置Rulers规范代码长度 

搜索