阅读量:0
在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
,则表示第一个元素应该排在第二个元素之后或保持不变。这种比较方式被称为“严格弱序”。