在C++中,你可以通过自定义一个比较函数(cmp function)来实现自定义的比较逻辑
#include<iostream>
#include<vector>
#include<algorithm>
// 自定义比较函数
bool cmp(int a, int b) {
return a > b; // 降序排列
}
int main() {
std::vector<int> numbers = {3, 1, 4, 1, 5, 9, 2, 6};
// 使用自定义比较函数对vector进行排序
std::sort(numbers.begin(), numbers.end(), cmp);
// 输出排序后的结果
for (int num : numbers) {
std::cout<< num << " ";
}
return 0;
}
在这个例子中,我们定义了一个名为cmp
的比较函数,它接受两个整数参数a
和b
。如果a
大于b
,则返回true
,否则返回false
。这样,当我们使用std::sort
函数并传入cmp
作为比较函数时,它会按照降序方式对numbers
向量进行排序。
注意:在C++中,比较函数应该返回一个布尔值,表示两个元素之间的比较关系。对于std::sort
函数,如果比较函数返回true
,则表示第一个元素应该排在第二个元素之前。如果返回false
,则表示第一个元素应该排在第二个元素之后或保持不变。这种比较方式被称为“严格弱序”。