我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用Lambda表达式编写递归

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用Lambda表达式编写递归

这篇文章主要介绍“如何使用Lambda表达式编写递归”,在日常操作中,相信很多人在如何使用Lambda表达式编写递归问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用Lambda表达式编写递归”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

递归参数及返回值类型假定

对于常见的递归函数,如:阶乘、斐波那契数列求值,我们先作如下假定:

参数为 int 类型(Int32);

返回值为 long 类型(Int64)。

基于假推断各类型

FIX g 类型

根据上篇文章中的描述:

FIX g = λn. (ISZERO n) 1 (MULT n ((FIX g) (PRED n)))FIX g 55 = 5 * (4 * (3 * (2 * (1 * 1))) = 120

FIX g 返回的是我们需要的递归函数,这个递归函数

·接收一个 int 参数(上面假定第 1 条)值为 5

·返回一个 long 型数值(上面假定第 2 条)120。

因此,确定出 FIX g 的类型可表示为 Func<int, long>。

同时也能看出 n 是递归函数的参数,n 类型为 int。

g 类型

阶乘单步函数如下:

g = &lambda;f. &lambda;n. (ISZERO n) 1 (MULT n (f (PRED n)))

c# 中可表达为:g => f => n => n == 0 ? 1 : n * f(n &ndash; 1)

先来推断 f 的类型:

&middot;f 的参数:f 接收 n &ndash; 1 作为参数,因此,f 参数的类型和 n &ndash; 1 类型相同,即 n 的类型:int;

&middot;f 的返回值:为 0 时返回 1,否则返回 n * f(n-1),f 的返回值类型也就是整个递归函数的返回值类型,即 long。

可确定 f 类型为 Func<int, long>。

n => n == 0 ? 1 : n * f(n &ndash; 1) 是传入一个 int 返回一个 long,其类型 Func<int, long>。

先来变换下 g 的表示形式:

var g = (Func<int, long> f) => {      Func<int, long> t =           n => n == 0 ? 1 : n * f(n - 1);      return t;  };  // 示意代码

从上面这段代码可以清楚到看出 g 接收一个 Func<int, long> 类型的参数 f,返回一个类型为 Func<int, long> 的委托,可得出:

g 的类型为 Func<Func<int, long>, Func<int, long>>

FIX 类型

FIX g 可写作 FIX(g),可以看出: FIX g 的类型 == FIX(g) 的类型 == FIX 返回值的类型。前面得知 FIX g 类型为 Func<int, long>,也就可推出 FIX 返回值类型为 Func<int, long>。

FIX 接受 g 作为参数,FIX 的参数类型也就是 g 的类型,可知 FIX 参数类型为 Func<Func<int, long>, Func<int, long>>。

由此得出 FIX 的类型为:Func<Func<Func<int, long>, Func<int, long>>, Func<int, long>>。

(估计这是多数开发人员见过的最复杂的泛型了。后面还在更复杂的吆!)

小结

名称&lambda; 演算表达式数据类型
输入参数nint
迭归返回值FIX g nlong
迭归函数FIX gFunc<int, long>
单步函数gFunc<Func<int, long>, Func<int, long>>
不动点组合子FIXFunc<Func<Func<int, long>, Func<int, long>>, Func<int, long>>

通用类型

基于以上部分的推演和小结,我们可以归纳出通用类型:

名称&lambda; 演算表达式数据类型
输入参数nTInput
迭归返回值FIX g nTResult
迭归函数FIX gFunc<TInput, TResult>
单步函数gFunc<Func<TInput, TResult>, Func<TInput, TResult>>
不动点组合子FIXFunc<Func<Func<TInput, TResult>, Func<TInput, TResult>>, Func<TInput, TResult>>

基于本文推断出的类型,不动点组合子转换为 c# 代码了不容易多了。

到此,关于“如何使用Lambda表达式编写递归”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用Lambda表达式编写递归

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用Lambda表达式编写递归

这篇文章主要介绍“如何使用Lambda表达式编写递归”,在日常操作中,相信很多人在如何使用Lambda表达式编写递归问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用Lambda表达式编写递归”的疑惑有所
2023-06-17

如何使用Lambda表达式编写递归函数

这篇文章主要介绍“如何使用Lambda表达式编写递归函数”,在日常操作中,相信很多人在如何使用Lambda表达式编写递归函数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用Lambda表达式编写递归函数
2023-06-17

怎么使用Lambda表达式编写递归

本篇内容主要讲解“怎么使用Lambda表达式编写递归”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用Lambda表达式编写递归”吧!使用 Lambda 表达式构建递归函数很多朋友认为这很容
2023-06-17

C#如何实现递归调用的Lambda表达式

这篇文章主要讲解了“C#如何实现递归调用的Lambda表达式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#如何实现递归调用的Lambda表达式”吧!首先给一个简单的示例: int
2023-07-02

python如何使用Lambda表达式

这篇文章主要为大家展示了“python如何使用Lambda表达式”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python如何使用Lambda表达式”这篇文章吧。Lambda表达式厌倦了定义用不
2023-06-27

C++ 中如何使用lambda表达式?

lambda 表达式是 c++++ 中的匿名函数,用于创建一次性的函数。它们通过捕获列表访问外部作用域变量,并可以接收参数和定义返回类型。lambda 表达式通常用于快速创建或在运行时传递函数。它们可以访问 lvalue 和 rvalue,
C++ 中如何使用lambda表达式?
2024-04-12

C#中如何使用Lambda表达式

本篇文章为大家展示了C#中如何使用Lambda表达式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C# Lambda表达式我们从“所有字符串查找包含YJingLee子字符串”说起。在C# 2.0中,
2023-06-17

C#中Lambda表达式如何使用

本篇内容介绍了“C#中Lambda表达式如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、介绍1、"Lambda表达式"是一个特殊的
2023-06-30

Java的Lambda表达式如何使用

这篇文章主要介绍“Java的Lambda表达式如何使用”,在日常操作中,相信很多人在Java的Lambda表达式如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的Lambda表达式如何使用”的疑
2023-06-30

C++11中lambda表达式如何使用

本篇文章为大家展示了C++11中lambda表达式如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先这个lambda就是罗马字母λ,lambda表达式即λ表达式。数学上有一个概念叫λ演算,其
2023-06-19

Lambda表达式如何在Android 中使用

这篇文章给大家介绍Lambda表达式如何在Android 中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.Lambda表达式的基本写法如果想要在 Android 项目中使用 Lambda表达式 或者 Java8
2023-05-31

如何在Java8中使用lambda表达式

这篇文章给大家介绍如何在Java8中使用lambda表达式,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 0. 函数式编程 函数式编程(Functional Programming)属于编程范式(Programm
2023-06-14

lambda表达式如何在java中使用

这篇文章给大家介绍lambda表达式如何在java中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Lamda表达式λ 希腊字母表中排序第十一位字母,英语名称为Lambda避免匿名内部类定义过多其实质属于函数式 编程
2023-06-14

lambda表达式如何在JAVA8中使用

这期内容当中小编将会给大家带来有关lambda表达式如何在JAVA8中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一:什么是 Stream?Stream(流)是一个来自数据源的元素队列并支持聚合操作
2023-06-15

C++ lambda 表达式如何定义和使用?

c++++ lambda 表达式是匿名函数,用于内联定义函数,使用语法:[capture list](parameters) -> return_type {函数体}。它们可以捕获外部范围内的变量,传递参数,并指定返回类型。lambda 表
C++ lambda 表达式如何定义和使用?
2024-04-17

如何在Java项目中使用lambda表达式

这期内容当中小编将会给大家带来有关如何在Java项目中使用lambda表达式,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java8引入了lambda表达式。lambda表达式并不是新功能,只是为了方便代
2023-05-31

如何使用.NET Lambda表达式实现委托

本篇内容介绍了“如何使用.NET Lambda表达式实现委托”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!.NET Lambda表达式的写法
2023-06-18

lambda表达式如何在Android Studio应用中使用

本篇文章为大家展示了lambda表达式如何在Android Studio应用中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。根目录下gradle文件配置buildscript { reposi
2023-05-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录