第08章 递归与搜索(上).pptVIP

  1. 1、本文档共41页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第08章 递归与搜索(上)

第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) #include stdio.h int f(int n) //求第n项对3取余得到的余数 { if(n==0) return 1; else if(n==1) return 2; else return ( f(n-1)+f(n-2) )%3; } int main( ) { int f0[8]; for( int i=0; i8; i++ ) //把前8项的余数保存下来 f0[i] = f(i); int n; while( scanf( %d, n )!=EOF ) { if( f0[n%8]==0 ) printf( yes\n ); else printf( no\n ); } return 0; } 例8.7 分形(Fractal) 题目来源:Asia 2004, Shanghai (Mainland China), Preliminary 题号:ZOJ2423,POJ2083 题目描述: 分形是存在“自相似”的一个物体或一种量,从某种技术角度来说,这种“自相似”是全方位的。盒形分形定义如下: 度数为1的分形很简单,为: X 度数为2的分形为: X X X X X 如果用B(n-1)代表度数为n-1的盒形分形,则度数为n的盒形分形可以递归地定义为: B(n-1) B(n-1) B(n-1) B(n-1) B(n-1) 你的任务是输出度数为n的盒形分形。 输入描述: 输入文件包含多个测试数据,每个测试数据占一行,包含一个正整数n,n≤7。输入文件的最后一行为-1,代表输入结束。 第二种输入方式!!!!! 输出描述: 对每个测试数据,用符号“X”输出盒形分形。在每个测试数据对应的输出之后输出一个短划线符号“-”,在每行的末尾不要输出任何多余的空格,否则得到的是“格式错误”的结果。 注意:这道题目在ZOJ和POJ上对输出的要求不一样;在ZOJ上要求在每行的末尾不要输出多余的空格,而在POJ上要求每行的宽度一样,这样某些行末尾有若干个空格。 * 信息学院信息技术教研室 程序设计方法及在线实践 在数学上,求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 )

文档评论(0)

xiaolan118 + 关注
实名认证
文档贡献者

你好,我好,大家好!

版权声明书
用户编号:7140162041000002

1亿VIP精品文档

相关文档