递归函数和非递归函数的转变讲解课件_第1页
递归函数和非递归函数的转变讲解课件_第2页
递归函数和非递归函数的转变讲解课件_第3页
递归函数和非递归函数的转变讲解课件_第4页
递归函数和非递归函数的转变讲解课件_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、递归函数和非递归函数的转变讲解递归函数和非递归函数的转变讲解6.1 什么是递归6.1.1 递归的定义 在定义一个过程或函数时出现调用本过程或本函数的成分,称之为递归。若调用自身,称之为直接递归。若过程或函数p调用过程或函数q,而q又调用p,称之为间接递归。 6.1 什么是递归例 求n!(n为正整数) 。 一般的方法:n! = 1*2*(n-1)*n 递归的方法:例 求n!(n为正整数) 。 int factorial(int n) int x; if (n=0) x=1; else x=factorial (n-1)*n; return(x); 在该函数factorial (n)求解过程中,直

2、接调用factorial (n-1)自身,所以它是一个直接递归函数。 int factorial(int n)递归函数和非递归函数的转变讲解 int factorial(int n) int x; if (n=0) x=1; else x=factorial (n-1)*n; return(x); n=4n=3n=2n=1n=0 int factorial(int n)n=4n=36.1.2 何时使用递归 在以下三种情况下,常常要用到递归的方法。 1. 定义是递归的 2. 数据结构是递归的 3. 问题的求解方法是递归的 6.1.2 何时使用递归1. 定义是递归的 有许多数学公式、数列等的定义是

3、递归的。这些问题的求解过程可以将其递归定义直接转化为对应的递归算法。 例如,求Fibonacci数列:1. 定义是递归的2. 数据结构是递归的 有些数据结构是递归的。例如,第2章中介绍过的单链表就是一种递归数据结构,其结点类型定义如下: typedef struct LNode ElemType data; struct LNode *next; LinkList;2. 数据结构是递归的 对于递归数据结构,采用递归的方法编写算法既方便又有效。例如,求一个不带头结点的单链表head的所有data域(假设为int型)之和的递归算法: int Sum(LinkList *head) if (head

4、=NULL) return 0; else return (head-data+Sum(head-next); 对于递归数据结构,采用递归的方法编写算法既方便又3. 问题的求解方法是递归的 有些问题的解法是递归的,典型的有汉诺塔(Tower of Hanoi)问题求解:盘片移动时必须遵守以下规则:每次只能移动一个盘片;盘片可以插在A,B和C中任一塔座;不能将一个较大的盘片放在较小的盘片上。3. 问题的求解方法是递归的盘片移动时必须遵守以下规则:Hanoi(n,a,b,c)Hanoi(n-1,a,c,b);move(n,a,c);Hanoi(n-1,b,a,c)Hanoi(n,a,b,c)Han

5、oi(n-1,a,c,b)6.1.3 递归模型 递归模型是递归算法的抽象,它反映递归问题的递归结构,例如,前面的递归算法对应的递归模型如下:fun(0)=1 n=0(1) fun(n)=n*fun(n-1)n0(2) 其中:第一个式子给出了递归的终止条件,我们称之为递归出口;第二个式子给出了fun(n)的值与fun(n-1)的值之间的关系,我们称之为递归体。6.1.3 递归模型 一般地,一个递归模型是由递归出口和递归体两部分组成, 前者确定递归到何时结束, 后者确定递归求解时的递推关系。递归出口的一般格式如下: f(s1)=m1 (6.1) 这里的s1与m1均为常量,有些递归问题可能有几个递归

6、出口。 一般地,一个递归模型是由递归出口和递归体两部分组 递归体的一般格式如下: f(sn+1)=g(f(si),f(si+1),f(sn),cj,cj+1,cm) (6.2) 其中, n,i,j,m均为正整数。 sn+1是一个递归“大问题”, si,si+1,sn为递归“小问题”, cj,cj+1,cm是可以用非递归方法直接解决的问题 g是一个非递归函数,可以直接求值。 递归体的一般格式如下:递归思路 实际上, 递归思路是把一个不能或不好直接求解的“大问题”转化成一个或几个“小问题”来解决,再把这些“小问题”进一步分解成更小的“小问题”来解决,如此分解,直至每个“小问题”都可以直接解决(此时

7、分解到递归出口)。 但递归分解不是随意的分解,递归分解要保证“大问题”与“小问题”相似,即求解过程与环境都相似。并且有一个分解的终点。从而使问题可解。 递归思路求解5!的过程如下:求解5!的过程如下:斐波那契数列的递归调用树斐波那契数列的递归调用树递归的执行过程由分解过程和求值过程两部分构成。 分解过程是“量变”过程,即原来的“大问题”在慢慢变小,但尚未解决;遇到递归出口后,便发生了“质变”,即原递归问题便转化成直接问题。递归的执行过程由分解过程和求值过程两部分构成。 分解过程是“6.2 递归算法的设计 递归的求解的过程均有这样的特征:先将整个问题划分为若干个子问题,通过分别求解子问题,最后获

8、得整个问题的解。而这些子问题具有与原问题相同的求解方法,于是可以再将它们划分成若干个子问题,分别求解,如此反复进行,直到不能再划分成子问题,或已经可以求解为止。这种自上而下将问题分解、求解,再自上而下引用、合并,求出最后解答的过程称为递归求解过程。这是一种分而治之的算法设计方法。 递归算法设计先要给出递归模型,再转换成对应的C/C+语言函数。6.2 递归算法的设计 递归设计的步骤如下: (1)对原问题f(s)进行分析,假设出合理的“较小问题”f(s)(与数学归纳法中假设n=k-1时等式成立相似); (2)假设f(s)是可解的,在此基础上确定f(s)的解,即给出f(s)与f(s)之间的关系(与数

9、学归纳法中求证n=k时等式成立的过程相似); (3)确定一个特定情况(如f(1)或f(0)的解,由此作为递归出口(与数学归纳法中求证n=1时等式成立相似)。 递归设计的步骤如下: 例如,采用递归算法求实数数组A0.n-1中的最小值。 假设f(A,i)函数求数组元素A0Ai中的最小值。 当i=0时,有f(A,i)=A0; 假设f(A,i-1)已求出,则f(A,i)=MIN(f(A,i-1),Ai),其中MIN()为求两个值较小值函数。因此得到如下递归模型: A0 当i=0时 f(A,i)= MIN(f(A,i-1),Ai) 其他情况 例如,采用递归算法求实数数组A0.n-1中的由此得到如下递归求

10、解算法: float f(float A,int i) float m; if (i=0) return A0; else m=f(A,i-1); if (mAi) return Ai; else return m; 由此得到如下递归求解算法:6.3 递归算法到非递归算法的转换 递归算法有两个基本特性:一是递归算法是一种分而治之的、把复杂问题分解为简单问题的求解问题方法,对求解某些复杂问题,递归算法分析问题的方法是十分有效的;二是递归算法的时间/空间效率通常比较差。 因此,对求解某些问题时,我们希望用递归算法分析问题,用非递归算法具体求解问题。这就需要把递归算法转换为非递归算法。6.3 递归算

11、法到非递归算法的转换把递归算法转化为非递归算法有如下三种基本方法: (1)通过分析,跳过分解过程,直接用循环结构的算法实现求值过程。 (2)自己用栈模拟系统的运行时栈,通过分析只保存必须保存的信息,从而用非递归算法替代递归算法。 (3)利用栈保存参数,由于栈的后进先出特性吻合递归算法的执行过程,因而可以用非递归算法替代递归算法。把递归算法转化为非递归算法有如下三种基本方法:6.3.1 利用循环跳过分解过程从而消除递归 采用循环结构消除递归。求解Fibonacci数列的算法如下: int Fib(int n) int i,f1,f2,f3; if (n=1 | n=2) return(n); f

12、1=1;f2=2; for (i=3;i-1) /*栈不空时循环*/ if (Sttop.tag=1) /*未计算出栈顶元素的vf值*/ if (Sttop.vn=0)/*(1)式*/ Sttop.vf=1; Sttop.tag=0; else/*(2)式*/ top+; Sttop.vn=Sttop-1.vn-1; Sttop.tag=1; 对应的非递归fun1算法如下:else if (Sttop.tag=0) /*已计算出vf值*/ Sttop-1.vf=Sttop-1.vn*Sttop.vf; /*(2)式*/ Sttop-1.tag=0; top-; /*栈中只有一个已求出vf的元素时退出循环*/

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论