如何在C++中自定義cmp函數(shù)

c++
小樊
82
2024-09-09 08:56:08

在C++中,自定義比較函數(shù)(cmp function)通常用于排序和查找算法

#include<iostream>
#include<vector>
#include<algorithm>

// 自定義比較函數(shù)
bool my_cmp(int a, int b) {
    return a > b; // 降序排列
}

int main() {
    std::vector<int> numbers = {3, 1, 4, 1, 5, 9, 2, 6};

    // 使用自定義比較函數(shù)對(duì)vector進(jìn)行排序
    std::sort(numbers.begin(), numbers.end(), my_cmp);

    // 輸出排序后的結(jié)果
    for (int num : numbers) {
        std::cout<< num << " ";
    }

    return 0;
}

在這個(gè)例子中,我們定義了一個(gè)名為my_cmp的比較函數(shù),它接受兩個(gè)整數(shù)參數(shù)。這個(gè)函數(shù)返回一個(gè)布爾值,表示第一個(gè)參數(shù)是否大于第二個(gè)參數(shù)。在這種情況下,我們實(shí)現(xiàn)了降序排列。

然后,我們創(chuàng)建了一個(gè)包含一些整數(shù)的std::vector,并使用std::sort函數(shù)對(duì)其進(jìn)行排序。我們將my_cmp作為第三個(gè)參數(shù)傳遞給std::sort,以便使用我們的自定義比較函數(shù)。

最后,我們遍歷并輸出排序后的整數(shù)。

0