c++

C++ sort lambda如何自定义排序规则

小樊
104
2024-07-19 02:12:34
栏目: 编程语言

在C++中,我们可以使用lambda表达式来自定义排序规则。通过lambda表达式,我们可以指定自定义的比较函数,并将其作为参数传递给std::sort函数。

以下是一个示例,展示如何使用lambda表达式来自定义排序规则:

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

int main() {
    std::vector<int> numbers = {5, 2, 8, 1, 9};
    
    // 使用lambda表达式自定义排序规则,按照数字的平方进行排序
    std::sort(numbers.begin(), numbers.end(), [](int a, int b) {
        return a * a < b * b;
    });

    // 打印排序后的结果
    for (int num : numbers) {
        std::cout << num << " ";
    }

    return 0;
}

在上面的示例中,我们使用lambda表达式[](int a, int b) { return a * a < b * b; }来定义自定义的排序规则,即按照数字的平方进行排序。然后将这个lambda表达式作为第三个参数传递给std::sort函数,以实现按照自定义规则进行排序。

通过lambda表达式,我们可以很方便地在不同的场景下定义不同的排序规则,使得代码更加灵活和可复用。

0
看了该问题的人还看了