第08章 递归及搜索(上).ppt

  1. 1、本文档共39页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8章 递归与搜索(上) 第8章 递归与搜索 递归是一种重要的算法思想。 递归既可以实现递推过程,也可以实现求解诸多问题的通用思路―搜索。 8.1 递归的基本思想 8.1.1 什么是递归 8.1.2 递归例题解析 结论 Hanoi(3,A,B,C)的执行过程 8.1.3 递归存在的问题 递归思想虽然很好理解,特别是对于一些可以用递推式子表示的问题。然而,使用递归的代价是十分巨大的:它会消耗大量的内存!!! 函数调用时需要用到堆栈,而堆栈的资源是十分有限的。 在例8.3中,使用递归思想求Fibonacci数列的第n项。单独求Fibonacci(20),递归调用Fibonacci( )函数就达到21891次!!!这一点可以用下面的代码验证。 8.2 递归思想在竞赛试题中的应用 例8.6 另一个Fibonacci数列(Fibonacci Again) 例8.7 分形(Fractal) * 信息学院信息技术教研室 程序设计方法及在线实践 在数学上,求n的阶乘,有两种表示方法: ① n!= n×(n-1)×(n-2)×…×2×1 ② n!= n×(n-1)! 这两种表示方法实际上对应到两种不同的算法思想。 第①种表示方法中,求n!要反复把1、2、3、…、(n-2)、(n-1)、n累乘起来,是循环的思想,要用循环结构来实现,代码如下: int n, F=1; scanf( %d, n ); for( i=1; i=n; i++ ) F = F*i; printf( %d的阶乘为%d, n, F ); 第②种表示方法,求n!时需要用到(n-1)!。如果有一个函数Factorial( int n )能实现求n的阶乘,则该函数在求n!时要使用到表达式:n*Factorial(n-1),Factorial(n-1)表示调用Factorial( )函数去求(n-1)!。具体代码例8.1。 例8.1 递归求阶乘 #include stdio.h int Factorial( int n ) { if( n0 ) return -1; else if( n==0 || n==1 ) return 1; else return n*Factorial(n-1); //递归调用Factorial函数 } int main( ) { int A; scanf( %d, A ); printf( %d!=%d\n, A, Factorial(A) ); return 0; } 该程序的运行示例如下: 4↙ 4!=24 int Factorial( int n ) { if( n0 ) return -1; else if( n==0 || n==1 ) return 1; else return n*Factorial(n-1); } Factorial( )函数有一个特点,它在执行过程中又调用了Factorial( )函数,这种函数称为递归函数。 具体来说,在执行一个函数过程中,又直接或间接地调用该函数本身,如图8.1所示,这种函数调用称为递归调用;包含递归调用的函数称为递归函数。 假设要求3!,其完整的执行过程如图8.2所示,具体过程为: ①执行main函数的开头部分; ②当执行到Factorial函数调用“Factorial(3)”时,流程转而去执行Factorial(3)函数,并将实参3传递给形参n; ③执行Factorial(3)函数的开头部分; ④当执行到递归调用Factorial(n-1)函数时,此时n-1=2,所以要转而去执行Factorial(2)函数; ⑤执行Factorial(2)函数的开头部分; ⑥当执行到递归调用Factorial(n-1)函数时,此时n-1=1,所以要转而去执行Factorial(1)函数; ⑦执行Factorial(1)函数,此时因为n的值为1,所以返回1,而不是再递归调用下去,即,Factorial(1)函数执行完毕,返回到上一层,即返回Factorial(2)函数中; ⑧执行完Factorial(2)函数的剩余语句,返回到Factorial(3)函数中; ⑨执行完Factorial(3)函数的剩余语句,返回到main函数中; ⑩继续执行main函数的剩余部分直到整个程序执行完毕。 例8.2 猴子吃桃问题。猴子第1天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第2天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半另加一个。到第10天早上想再吃时,就只剩下一个桃子了。求第1天共摘了多少个桃子。 分析: 假设Ai为第i天吃完后剩下的桃子的个数,A0表示第一天共摘下的桃子,本题要求的是A0。有以下递推式子: A0 = 2×(A1+1) A1:第1天吃完后剩

文档评论(0)

kehan123 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档