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

c++
791
2024/9/9 9:31:48
栏目: 编程语言
开发者测试专用服务器限时活动,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,则表示第一个元素应该排在第二个元素之后或保持不变。这种比较方式被称为“严格弱序”。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: c++默认构造函数怎样重载