C++中使用cmp函数实现自定义比较逻辑的方法

avatar
作者
猴君
阅读量: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的比较函数,它接受两个整数参数ab。如果a大于b,则返回true,否则返回false。这样,当我们使用std::sort函数并传入cmp作为比较函数时,它会按照降序方式对numbers向量进行排序。

注意:在C++中,比较函数应该返回一个布尔值,表示两个元素之间的比较关系。对于std::sort函数,如果比较函数返回true,则表示第一个元素应该排在第二个元素之前。如果返回false,则表示第一个元素应该排在第二个元素之后或保持不变。这种比较方式被称为“严格弱序”。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!