自定义排序规则可通过Lambda表达式、函数对象或普通函数实现,例如用Lambda按二维数组第二列升序排列:std::sort(data.begin(), data.end(), [](const auto& a, const auto& b) { return a[1] < b[1];})。

在C++中,自定义排序规则是处理复杂数据类型或非默认顺序需求时的常用操作。通过std::sort函数结合自定义比较逻辑,可以灵活控制排序行为。核心方法包括:函数对象、Lambda表达式和普通函数指针。下面介绍几种实用技巧。
Lambda是现代C++中最简洁的方式,适合简单逻辑。
示例:对二维数组按第二列升序排列:
std::vector<std::vector<int>> data = {{1, 3}, {2, 1}, {3, 2}};<br>
std::sort(data.begin(), data.end(), [](const auto& a, const auto& b) {<br>
return a[1] < b[1];<br>
});代码中Lambda接收两个参数,返回true表示第一个应排在第二个之前。
立即学习“C++免费学习笔记(深入)”;
当比较逻辑较复杂或需复用时,定义结构体更清晰。
struct Compare {<br>
bool operator()(const std::string& a, const std::string& b) const {<br>
return a.length() < b.length(); // 按长度排序<br>
}<br>
};<br>
<br>
std::vector<std::string> words = {"hi", "hello", "ok"};<br>
std::sort(words.begin(), words.end(), Compare{});结构体重载了operator(),可像函数一样调用。
适用于C风格接口或需要传递函数名的场景。
bool cmp(const int& a, const int& b) {<br>
return a > b; // 降序排列<br>
}<br>
<br>
std::vector<int> nums = {3, 1, 4, 1, 5};<br>
std::sort(nums.begin(), nums.end(), cmp);注意函数签名要匹配std::sort要求的二元谓词格式。
确保比较函数满足严格弱序(strict weak ordering),否则行为未定义。常见错误包括:
<可能因精度问题出错,建议加容差判断std::sort(people.begin(), people.end(), [](const Person& a, const Person& b) {<br>
if (a.name != b.name) return a.name < b.name;<br>
return a.age < b.age;<br>
});基本上就这些。掌握Lambda和函数对象,就能应对大多数排序定制需求。关键是写清楚“什么情况下前者应排在后者前面”。
以上就是c++++中如何自定义排序规则_c++排序规则自定义技巧的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号