用 C++ lambda 表达式自定义排序规则如何实现?

使用 c++++ lambda 表达式自定义排序规则,可灵活定义排序逻辑。语法为:[capture list](parameters) -> return type { body }。实战案例中,lambda 表达式 sortlambda

使用 c++++ lambda 表达式自定义排序规则,可灵活定义排序逻辑。语法为:[capture list](parameters) -> return type { body }。实战案例中,lambda 表达式 sortlambda 按字符串长度排序,输出为:dog、apple、banana、cherry、elephant。

用 C++ lambda 表达式自定义排序规则如何实现?

用 C++ Lambda 表达式自定义排序规则

Lambda 表达式是一种匿名函数,可以在 C++ 中用来定义自定义排序规则。它提供了简便灵活的方式,使您可以根据自定义逻辑对数据进行排序。

语法

典型的 lambda 表达式语法如下:

[capture list](parameters) -> return type { body }

登录后复制

其中:

  • capture list:可选,用于捕获对外部变量的引用。
  • parameters:可选,用于获取输入参数。
  • -> return type:可选,用于指定返回类型。
  • body:函数体,包含要执行的代码。

实战案例

下面是一个使用 lambda 表达式自定义排序规则的实战案例,用于对一个字符串向量按其长度排序:

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

using namespace std;

int main() {
    vector<string> strings = {"apple", "banana", "cherry", "dog", "elephant"};

    // 定义 lambda 表达式,将字符串按长度排序
    auto sortLambda = [](const string& a, const string& b) { return a.length() < b.length(); };

    // 使用 lambda 表达式对向量排序
    sort(strings.begin(), strings.end(), sortLambda);

    // 打印排序后的向量
    for (const string& s : strings) {
        cout << s << endl;
    }

    return 0;
}

登录后复制

输出

dog
apple
banana
cherry
elephant

登录后复制

在这个示例中,lambda 表达式 sortLambda 捕获了对外部变量 ab 的引用,并返回 a 的长度是否小于 b 的长度。排序函数 sort 使用此 lambda 表达式对字符串向量进行排序,按字符串的长度升序排列

以上就是用 C++ lambda 表达式自定义排序规则如何实现?的详细内容,更多请关注叮当号网其它相关文章!

文章来自互联网,只做分享使用。发布者:周斌,转转请注明出处:https://www.dingdanghao.com/article/364504.html

(0)
上一篇 2024-04-17 18:40
下一篇 2024-04-17 19:20

相关推荐

联系我们

在线咨询: QQ交谈

邮件:442814395@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信公众号