百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

少侠留步!你知道if、while和递归之间的关系吗?

yuyutoo 2024-10-14 16:25 2 浏览 0 评论

少侠们好~

又和大家见面了,

(又可以和大家吹牛逼了~)

这次要分享的东西是一篇秘籍,

一篇简单的关于if, while和递归之间关系的秘籍。

不管少侠对它们了解的怎么样,

希望这篇文章能够对你有那么一点点帮助~

或者,

发现一些有趣的东西也说不定呢~

好了,

现在开始进入正题:

首先,这有一个熟悉的数组:

然后,

我们现在来使用迭代,

试着对它里面的数字进行求和~

这里使用while语句,

少侠你一定觉得很简单是不是?

我们依次遍历每个数字,

添加到sum上,直到数组的末尾。

不过,

今天我们的任务是,

如何用递归的方式来实现这个功能。

实际上,

用递归替换掉while,

可能比少侠你想的要简单很多。

不信?

不信的话少侠请系好安全带,

我们要发车了~


首先,第一步,

把while语句里面的内容,

放进一个函数里面:

同时我们给它一个名称,

叫做addNext:

这个函数虽然简单,不过还是比较有趣的,

我们每调用一次,它就会像sum里面添加一个数字。

这是它的使用方式:

这里,

我们通过3次调用,

计算除了nums里面3个数字的总和,

不过,

少侠你应该会说,

“,你这也太low了,我还得手动一次一次调用?万一有100个数字呢?我难道还要手动调用100次?”

没错,

少侠你可真是个小机灵鬼~

手动调用这么笨的方法,我们当然不会采用,

(刚才还在用呢。。。)

所以这里我们有2种选择,

第一种!

把它放进while里面,

好了,现在我们不用手动调用了,

“???”

当然,

这种情况和一开始没太大区别,一样用了while,

只不过把while里面的内容放进函数里面了。。。

但是!

我们还有第二种选择,

第二种选择就是,

既然addNext是一个函数了,那么,

我们能不能在它内部的末尾,让它自己继续调用addNext呢?

是可以的~

我们可以在addNext函数内部,增加个判断,

如果还有数字,让它自动调用addNext添加下一个数字。

好了,

完全OK~

今天的内容就到这里了。。。

“完了?”

“对啊,完了,没有while了啊。”

“你干某些事的时候速度也这么快吗~”

“。。。。。。”


好吧,

这么结束是有点不好。。

看看上面的函数,

少侠你应该可以发现了,

我们的addNext函数,就是一个递归函数,

也是它,帮助我们替代掉了while的功能,

不过,

我们外部的addAll函数并不算一个递归函数,

它内部的addNext函数才是,

那么,有没有办法使它自己就变成一个递归函数呢?

也是可以的!

不过这次我们重点不在这里,

这次我们想关注的是,

为什么我们可以使用递归来代替循环,

以及if, while和递归之间的关系。

少侠你平时应该已经用了非常多的if和while,

多到你可能都认为你完全理解它们了,

但是~

我想说少侠你还是太年轻了,

比如,

少侠你知道下面这句话什么意思不?

“if是懒惰的while, 除非它遇见了递归。”

不知道是吧?

你当然不知道,

因为这是我编的,哈哈哈哈~

“少废话了,有话赶紧说,有牛逼赶紧吹,大家时间都很宝贵的!”

好吧,

少侠请看:

“???”

“这不才上面看过吗?你是不是粘贴错了?”

没错没错~

这就是我们上面的代码,

但是现在我们要从另一个角度来看待它,

在这段代码里,while会不断遍历nums,直到所有的数字都添加完成,

那么,如果我们把while换成if,会是什么情况呢?

很明显,

因为if只会执行里面的代码一次,所以它只添加了第一个数字1到sum里面。

如果我们想实现和while一样的效果的话,我们得手动告诉if,让它多执行几次,

因为它很懒,所以每次需要我们提醒~

“又来了又来了!我都说了,如果nums是[1,2,3,4,5,6,7,8,9,10],那你不得写10个if? 如果是100个,1000个呢?”

我知道我知道!

按照现在这样,如果nums长度变长了,就变成下面这样了:

这就是为什么我们开始要用一个函数把if的代码包裹起来,

为什么呢?

因为,

我们不能在if语句内部告诉它重复执行当前if语句,

但是我们却可以在函数内部,告诉它重复调用当前函数,

所以,我们把if语句放在函数内部,

然后重复调用这个函数,就可以实现重复调用if的效果。

OK~

我们又一次的用递归替换掉了while迭代。

怎么样,

很简单吧?少侠~

好了,

现在真要结束了,

恭喜少侠你又成功发现并阅读完了一篇文章~

按照惯例,首先~

谢谢少侠你看到了这里,

然后~

现在少侠你应该大概知道了if, while 和递归之间的关系了。

也应该知道了如何用递归替换掉代码中的循环,

不过,

少侠也许你可以多想想,

为什么我们能用递归替换掉迭代?

是哪些规则支撑了我们完成这些操作呢?

我们在addNext函数内部通过函数名称访问到了addNext,

从而可以调用它执行下一次操作,

那么,如果是匿名函数呢?

不管怎样,

希望少侠你能试着以自己的方式理解一下,

弄清楚他们到底在做什么~

然后,

做一些好玩的东西~

“叮~ 恭喜你找到蓝色的recursion残卷,已成功添加到储物袋里。”

额外的资源:

少侠还记得上一次我们提到的compose和pipeline函数吗?

如果你有兴趣,

少侠你应该试着按照上面的步骤实现递归的compose和pileline函数了。

不要立刻偷看下面的答案!

compose函数:

pipeline函数的过程几乎一模一样,这里就不再重复了,

免得你们说我啰嗦!

?

相关推荐

自卑的人容易患抑郁症吗?(自卑会导致抑郁吗)

Filephoto[Photo/IC]Lowself-esteemmakesusfeelbadaboutourselves.Butdidyouknowthatovert...

中考典型同(近)义词组(同义词考题)

中考典型同(近)义词组...

WPF 消息传递简明教程(wpf messagebox.show)

...

BroadcastReceiver的原理和使用(broadcast-suppression)

一、使用中注意的几点1.动态注册、静态注册的优先级在AndroidManifest.xml中静态注册的receiver比在代码中用registerReceiver动态注册的优先级要低。发送方在send...

Arduino通过串口透传ESP 13板与java程序交互

ESP13---是一个无线板子,配置通过热点通信Arduino通过串口透传ESP13板与java程序交互...

zookeeper的Leader选举源码解析(zookeeper角色选举角色包括)

作者:京东物流梁吉超zookeeper是一个分布式服务框架,主要解决分布式应用中常见的多种数据问题,例如集群管理,状态同步等。为解决这些问题zookeeper需要Leader选举进行保障数据的强一致...

接待外国人英文口语(接待外国友人的英语口语对话)

接待外国人英文口语询问访客身份:  MayIhaveyourname,please?  请问您贵姓?  Whatcompanyareyoufrom?  您是哪个公司的?  Could...

一文深入理解AP架构Nacos注册原理

Nacos简介Nacos是一款阿里巴巴开源用于管理分布式微服务的中间件,能够帮助开发人员快速实现动态服务发现、服务配置、服务元数据及流量管理等。这篇文章主要剖析一下Nacos作为注册中心时其服务注册与...

Android面试宝典之终极大招(android面试及答案)

以下内容来自兆隆IT云学院就业部,根据多年成功就业服务经验,以及职业素养课程部分内容,归纳总结:18.请描述一下Intent和IntentFilter。Android中通过Intent...

除了Crontab,Swoole Timer也可以实现定时任务的

一般的定时器是怎么实现的呢?我总结如下:1.使用Crontab工具,写一个shell脚本,在脚本中调用PHP文件,然后定期执行该脚本;2.ignore_user_abort()和set_time_li...

Spark源码阅读:DataFrame.collect 作业提交流程思维导图

本文分为两个部分:作业提交流程思维导图关键函数列表作业提交流程思维导图...

使用Xamarin和Visual Studio开发Android可穿戴设备应用

搭建开发环境我们需要做的第一件事情是安装必要的工具。因此,你需要首先安装VisualStudio。如果您使用的是VisualStudio2010,2012或2013,那么请确保它是一个专业版本或...

Android开发者必知的5个开源库(android 开发相关源码精编解析)

过去的时间里,Android开发逐步走向成熟,一个个与Android相关的开发工具也层出不穷。不过,在面对各种新鲜事物时,不要忘了那些我们每天使用的大量开源库。在这里,向大家介绍的就是,在这个任劳任怨...

Android事件总线还能怎么玩?(android实现事件处理的步骤)

顾名思义,AndroidEventBus是一个Android平台的事件总线框架,它简化了Activity、Fragment、Service等组件之间的交互,很大程度上降低了它们之间的耦合,使我们的代码...

Android 开发中文引导-应用小部件

应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...

取消回复欢迎 发表评论: