- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
由此得到如下递归求解算法: float f(float A[ ] , int i) { float m; if (i==0) return A[0]; else { m=f(A, i-1); if (mA[i]) return A[i]; else return m; } } 例6.2: 利用串的基本运算写出对串求逆的递归算法. 解: 设 f(s)=s的逆串 String invert( string s ) { string s1, s2; if ( strlen( s )0 ) { s1=invert(substr(s,2,strlen(s)-1)); s2=concat(s2,substr(s,1,1)); } else StrCopy(s2 , s); return s2; } 例6.3 求顺序表L的最大元素。 ElemType Max(SqList L, int i, int j ) // 求第i~j元素中的最大值 { int mid; ElemType max,max1,max2; if (i==j) max=L.data[i]; else { mid=(i+j)/2; max1=Max(L, i, mid); // 求第i~mid元素中的最大值 max2=Max(L, mid+1, j); // 求第mid~j元素中的最大值 max=(max1max2)? max1:max2; } return max; } 6.4 递归算法到非递归算法的转换 递归算法有两个基本特性:一是递归算法是一种分而治之的、把复杂问题分解为简单问题的求解问题方法,对求解某些复杂问题,递归算法分析问题的方法是十分有效的;二是递归算法的时间效率通常比较差。因此,对求解某些问题时,我们希望用递归算法分析问题,用非递归算法具体求解问题。这就需要把递归算法转换为非递归算法。 把递归算法转化为非递归算法有如下三种基本方法: (1)对于尾递归和单向递归的算法,可用循环结构的算法替代。 (2)自己用栈模拟系统的运行时栈,通过分析只保存必须保存的信息,从而用非递归算法替代递归算法。 (3)利用栈保存参数,由于栈的后进先出特性吻合递归算法的执行过程,因而可以用非递归算法替代递归算法。 本节讨论第(1)种和第(2)种情况的递归算法转化为非递归算法的问题,前者是一种是直接转化法,不需要使用栈,后者是间接转化法,需要使用栈。第(3)种情况也需要使用栈,但因具体情况而异,例如,在第7章的例7.6就是这种情况的一个例子。 6.4.1 尾递归和单向递归的消除 采用循环结构消除尾递归和单向递归。 单向递归是指递归函数中虽然有一处以上的递归调用语句,但各次递归调用的参数只和主调用函数有关,相互间参数无关,且这些递归调用也处在算法的最后。 尾递归是指递归调用是算法的最后一条语句,当递归调用返回时,返回到上一层递归调用语句的下一语句,而这个返回位置正好是算法的末尾。因此,函数返回值和函数的参数等实际上在这里根本没有使用,所以对尾递归的算法,不必利用系统的运行栈保存各种信息。这样只需要将递归调用改为循环结构。 采用循环结构消除尾递归和单向递归。 例: Fibonacci数列:1,1,2,3,5,8,13,21,34,55,89,….。 f1=1, f2=1, fn=fn-1+fn-2 n2 求解Fibonacci数列的递归算法如下: int Fib(int n) { int f; if (n==1 | | n==2) return(1); f=Fib(n-1)+Fib(n-2); return(f); } * * 第6章 递归 6.3 递归算法到非递归算法的转换 6.1 什么是递归 6.2 递归算法的设计 本章小结 6.1 什么是递归 6.1.1 递归的定义 在定义一个过程或函数时出现调用本过程或本函数的成分
文档评论(0)