递归和迭代

递归和迭代一.递归(Recursion)1.递归:以相似的方式重复自身的过程2.递归在程序中表现为:在函数的定义中直接或间接调用函数自身3.递归和循环:(1)递归是有去(递去)有回(归来),因为存在终止

大家好,又见面了,我是你们的朋友全栈君。

一.递归(Recursion)

1.递归:以相似的方式重复自身的过程

2.递归在程序中表现为:在函数的定义中直接或间接调用函数自身

3.递归和循环:

(1)递归是有去(递去)有回(归来),因为存在终止条件,比如你打开一扇门还有一扇门,不断打开,最终你会碰到一面墙,然后返回

(2)循环是有去无回,但可以设置终止条件,比如你打开一扇门还有一扇门,不断打开,还有门,没有终点

4.递归的递去和归来:

(1)递归的递去:原问题必须可以分解成若干个子问题,而且子问题须与原始问题为同样的事(相似),且规模更小

(2)递归的归来:子问题的演化必须有一个明确的终点,否则可能导致无限递归(无终止条件的循环),也就是说不能无限制地调用本身,须有个出口,化简为非递归状况处理

5.递归在函数中的具体形式:

(1)必须明确终止条件,并给出终止时的处理

(2)必须有间接或直接调用自身解决小规模问题的步骤

def recursion(大规模问题):

  if end_condition:                                  #终止条件

    end                                               #终止的处理

  else:

    recursion(小规模子问题)    #调用自身

6.递归的应用:

(1)问题的定义是按递归定义的(Fibonacci函数,阶乘,…);

(2) 问题的解法是递归的(有些问题只能使用递归方法来解决,例如,汉诺塔问题,…);

(3) 数据结构是递归的(链表、树等的操作,包括树的遍历,树的深度,…)

7.递归的优缺点

(1)递归的优点:简洁,容易处理问题,代码可读性高

(2)时间和空间消耗大

8.递归式求解的基本方法

(1)代换法

1.猜对答案

2.用数学归纳法求解常系数,并验证递归式解的正确性

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

例:已知:<span role="heading" aria-level="2">递归和迭代T(n)= O(n lgn)

则计算<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

(2)递归树

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

(3)主方法:不是所有情况都包括

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

<span role="heading" aria-level="2">递归和迭代

 

二.迭代

1.迭代:是一种为了逼近所需目标或结果,不断用变量的旧值递推新值的过程

2.迭代在程序中的表现:函数不断调用原函数的返回值,

3.迭代与循环,迭代和递归一样,也是循环的一种

(1)循环:参与运算的变量同时是保存结果的变量

(2)迭代:当前保存的结果作为下一次循环计算的初始值。迭代则使用计数器结束循环。

4.迭代和递归

(1)迭代:函数内某段代码实现循环,函数调用时使用前一次循环的返回值作为初始值,A调用B,使5用计数器结束循环

(2)递归:重复调用自身实现循环,A调用A,设置结束条件

(3)递归中一定有迭代,但是迭代中不一定有递归,大部分可以相互转换.能用迭代的不用递归,

5.迭代在程序中的表示:

(1)必须设置计数器,可以通过计数设置或条件设置,否则会一直迭代

(2)必须有返回值可以作为再次迭代的初值

def iteration(A):

  return B

C

 

for i in range(n):

  C=interation(C)

6.迭代的优缺点

(1)优点:代码效率高,时间空间消耗比递归小

(2)缺点:不够简洁,容易混淆

 

 

 

 

 
 
 
 
 
 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154361.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • html网页中加入音乐播放器,[HTML5]简单网页本地音乐播放器[通俗易懂]

    html网页中加入音乐播放器,[HTML5]简单网页本地音乐播放器[通俗易懂]既然HTML5提出与本地交互方便,就想写个HTML5的本地音乐播放器。一开始问题主要集中在怎么读取本地文件路径,我想肯定可以用JS实现去操作本地文件(因为node.js很容易实现读取本地文件,但是原生JS怎么写不太清楚),不过简单一点就用这样只能读取一个,我想做的是最好是把一个文件夹中的都取出来,然后参考http://sapphion.com/2011/11/html5-folder-upload…

    2022年6月21日
    22
  • SEO学习(九)——快速网站诊断(Google网管工具)[通俗易懂]

    SEO学习(九)——快速网站诊断(Google网管工具)[通俗易懂]SEO服务商在刚刚与客户接触时,尤其需要对目标为网站做快速检查,发现其中的重要问题。一、快速诊断的步骤:   1、检查与研究竞争对手网站时同样的指标,另外还要计算页面收录比例(即搜索引擎收录页面数也网站实际总页面数之比)。   2、查看Google网站管理员工具给出的信息。二、Google网管工具1、robots文件检查     整个网站不能收录或某个目录下所有页面都不

    2022年9月28日
    4
  • mysql varchar列转成integer然后获取最大值。[通俗易懂]

    mysql varchar列转成integer然后获取最大值。[通俗易懂]https://blog.csdn.net/c_henjinxing521/article/details/51788963上面的大神写的办法可以。selectMAX(CAST(userNoasSIGNEDINTEGER))fromuserInfo;或者selectMAX(CAST(userNoasUNSIGNEDINTEGER))fromus…

    2025年9月1日
    6
  • ubuntu完全卸载CUDA

    ubuntu完全卸载CUDACUDA的卸载方法网上都有很多,但是几乎都是错的,我在卸载cuda时基本试了个遍,各种踩坑。能查到的方法一般都是从官方文档搬过来的,然而这种方法并不能将cuda完全卸掉。这里把官方文档的方法贴出来:sudoapt-get–purgeremove”*cublas*””*cufft*””*curand*”\”*cusolver*””*cusparse*””*npp*””*nvjpeg*””cuda*””nsight*”我运行过这个命令,运行完之后,命令行输入nvcc-

    2022年5月30日
    78
  • 河北专接本计算机专业课平均分,2019年河北专接本招生数据及通过率分析[通俗易懂]

    河北专接本计算机专业课平均分,2019年河北专接本招生数据及通过率分析[通俗易懂]每天都会有很多的同学咨询小编河北专接本各个专业的通过率,其实对于单科的通过率来说并不能作为你专接本选专业的首要因素,因为专接本的分数充满的随机性,同学们往往会被某专业专业的高通过率所迷惑从而做出错误的选择。那么易学仕小编整理了一下河北专接本2019年的通过率,仅供大家参考!经管类是财经类和管理类,19年刚刚合并为经管类!这个大类一共招收2667人,参加考试达到100分以上的人数是8686人,整体通…

    2022年7月16日
    35
  • 分析ICMP报文「建议收藏」

    分析ICMP报文「建议收藏」目录捕获准备:ICMP的相关知识:报文分析:捕获准备:启动wireshark录制数据包,打开命令行窗口输入pingwww.sina.com.cn。Wireshark已记录下报文,在过滤器输入ip.addr==120.192.83.125过滤报文。ICMP的相关知识:ICMP是(InternetControlMessage…

    2022年4月29日
    101

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号