使用 C Lambda 表达式自定义排序规则,可灵活定义排序逻辑。语法为:[capture list](parameters) -> return type { body }。实战案例中,lambda 表达式 sortLambda 按字符串长度排序,输出为:dog、apple、banana、cherry、elephant。
用 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
捕获了对外部变量 a
和 b
的引用,并返回 a
的长度是否小于 b
的长度。排序函数 sort
使用此 lambda 表达式对字符串向量进行排序,按字符串的长度升序排列。
以上是用 C++ lambda 表达式自定义排序规则如何实现?的详细内容。更多信息请关注PHP中文网其他相关文章!