温馨提示×

C++ next_permutation如何定制比较函数

c++
小樊
86
2024-07-13 04:24:27
栏目: 编程语言

在C ++中使用next_permutation时,可以通过自定义比较函数来指定排序规则。比较函数必须满足严格弱序关系,即满足反对称性、传递性和非对称性。

下面是一个示例,在next_permutation中使用自定义的比较函数,该比较函数将按照数字的绝对值大小进行排序:

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

bool compareAbs(int a, int b) {
    return abs(a) < abs(b);
}

int main() {
    std::vector<int> vec = {3, -1, 4, -5, 2};
    
    std::sort(vec.begin(), vec.end(), compareAbs);
    
    do {
        for (int i : vec) {
            std::cout << i << " ";
        }
        std::cout << std::endl;
    } while (std::next_permutation(vec.begin(), vec.end(), compareAbs));
    
    return 0;
}

在上面的示例中,compareAbs函数指定了按照数字的绝对值大小进行排序。然后在std::sortstd::next_permutation函数中传入该比较函数,从而实现按照绝对值大小进行排序和生成排列。

0