C++ Lambda表达式 在竞赛中提高你的代码连贯性

本文中的lambda表达式使用方式应该在目前的所有比赛中(C++11及以上)都是可以使用的,因为比较落后的蓝桥杯都更新到了C++14。

当题目做的越来越多,难度越来越大,相应的代码就会越来越长,通常在100行左右。

在行数这么多的基础上,如果要使用递归函数,或者是sort的cmp函数,就会需要在int main上面定义函数(代码写着写着往上翻,再去写),会使思维方向和代码方向并不一致。

本文提到的Lambda表达式用法仅对竞赛和做题方面相性较高(用不到捕获列表[],出现它只是为了满足Lambda表达式的格式),如果要详细了解Lambda表达式请看:C++Lambda表达式,超详细的讲解,保证一遍懂_c++ lambda-CSDN博客

sort-cmp 正常写法

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int a[10];

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

int main(){
    sort(a+1,a+10,cmp);
    return 0;
}

sort-cmp Lambda函数

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int a[10];

int main(){
    auto cmp=[](int a,int b){//在代码量大的时候,不需要跑到前面去自定义函数
        return a<b;          //思维和代码的连贯性提高很多
    };
    sort(a+1,a+10,cmp);
    return 0;
}

sort-cmp Lambda匿名函数

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int a[10];

int main(){
    sort(a+1,a+10,[](int a,int b){return a<b;});// <- 当lambda作为匿名函数使用的时候就不需要最后的封号了
    return 0;
}

三种写法都可以,任取其一。


但是Lambda函数无法写成递归。

递归 Lambda函数 错误写法

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int a[10];

int main(){
    a[1]=2;
    a[2]=3;
    a[3]=4;
    a[4]=4;
    auto dfs=[](int i){
        cout<<i<<" ";
        if(i==a[i])return;
        dfs(a[i]);
    };//<- 这个封号千万别忘了,和结构体一样,是格式。
    return 0;
}

他会显示编译不通过,我们只需要稍作修改,把Lambda函数自己作为参数传进去使用即可。

递归 Lambda函数 正确写法

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int a[10];

int main(){
    a[1]=2;
    a[2]=3;
    a[3]=4;
    a[4]=4;
    auto dfs=[](int i,auto dfs){
        cout<<i<<" ";
        if(i==a[i])return;
        dfs(a[i],dfs);
    };dfs(1,dfs);// <- 函数定义了记得使用
    return 0;
}

输出

很明显可以看到lambda来写递归和原本的递归,就是多了一个把自己当参数传进去的步骤。

可以先写好原来的dfs,然后加上这么一个参数就好了。

如果使用的是CLion这种智慧编译器,如果你的Lambda函数还没有写好return就已经使用dfs(a[i],dfs)来递归调用自己,那就会不停的报错,是正常的,因为Lambda函数的返回值是auto,自动选取。

如果你已经使用了dfs(a[i],dfs),但是没有return,编译器不知道是否存在返回值,提示你写return部分。


tip:Lambda表达式写在哪里都可以,并不局限在main函数里面,也可以是多组数据处理的solve函数里面。

相关推荐
汀、人工智能18 分钟前
[特殊字符] 第66课:跳跃游戏
数据结构·算法·数据库架构·图论·bfs·跳跃游戏
汀、人工智能27 分钟前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
wsoz32 分钟前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
y = xⁿ33 分钟前
【LeetCode】双指针:同向快慢针
算法·leetcode
啊哦呃咦唔鱼34 分钟前
LeetCode hot100-105从前序与中序遍历序列构造二叉树
算法
favour_you___35 分钟前
2026_4_8算法练习题
数据结构·c++·算法
汀、人工智能44 分钟前
[特殊字符] 第57课:搜索旋转排序数组
数据结构·算法·数据库架构·图论·bfs·搜索旋转排序数组
倦王1 小时前
力扣日刷47
算法·leetcode·职场和发展
MicroTech20251 小时前
突破量子数据加载瓶颈,MLGO微算法科技推出面向大规模量子计算的分治态制备技术
科技·算法·量子计算
码王吴彦祖1 小时前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法