- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第六章 递归算法
第6章 递归算 法 情景 小时候,我们听过这样的故事: 从前有座山,山上有座庙,庙里有个老和尚给小和尚讲故事,讲的是什么故事呢?从前有座山,山上有座庙,庙里有个老和尚给小和尚讲故事,讲的是什么故事呢?从前有座山,山上有座庙,庙里有个老和尚给小和尚讲故事,讲的是什么故事呢?…… 故事可以一直讲下去,每一个故事内容相同,单却是故事里的故事。 这就是现实里的递归! 选取数组的下标为low,上标为high,数组的中间位置下标mid=(low+high)/2; 如果x=a[mid],则查找成功; 如果xa[mid],则low=low,high=mid-1; 如果xa[mid],则low=mid+1,high=high; int f( int x) int f1( int x) int f2( int x) { int y, z; { int y, z; { int a,c; ┇ ┇ ┇ z=f(y); z=f2(y); c=f1(a); ┇ ┇ ┇ return(2*z); return(2*z); return(3+c); } } } (a) (b) 例如,要想将A柱上3个盘子移到C柱上,可以分解为以下三步: 1. 将A上2个盘子从A移到B(借助C)。 2. 将A上1个盘子从A移到C。 3. 将B上2个盘子从B移到C(借助A)。 其中第2步可以直接实现。第1步又可用递归方法分解为: 2.1 将A上1个盘子从A移到C。 2.2 将A上1个盘子从A移到B。 2.3 将C上1个盘子从C移到B。 第3步可以分解为: 3.1 将B上1个盘子从B移到A上。 3.2 将B上1个盘子从B移到C上。 3.3 将A上1个盘子从A移到C上。 上面第1步和第3步,都是把n-1个盘从一个柱移到另一个柱上,采取的办法是一样的,只是柱的名字不同而已。 写出程序输出结果 #includestdio.h int f(int a,int b,int n) { if(n==1) return a; if(n==1) return b; return f(b,a+b,n-1); } void main(){printf(%d,f(1,1,7));} void delete(LinkList L, ElemType x) { // 删除以L为头指针的带头结点的单链表中 // 所有值为x的数据元素 if (L-next) { if (L-next-data==x) { p=L-next; L-next=p-next; free(p); delete(L, x); } else delete(L-next, x); } } // delete 6.4 递归过程和运行时栈 对于非递归函数,调用函数在调用被调用函数前,系统要保存以下两类信息: (1)调用函数的返回地址; (2)调用函数的局部变量值。 当执行完被调用函数,返回调用函数前,系统首先要恢复调用函数的局部变量值,然后返回调用函数的返回地址。 递归函数被调用时,系统要做的工作和非递归函数被调用时系统要作的工作在形式上类同,但保存信息的方法不同。 递归函数被调用时,系统的运行时栈也要保存上述两类信息。 每一层递归调用所需保存的信息构成运行时栈的一个工作记录,在每进入下一层递归调用时,系统就建立一个新的工作记录,并把这个工作记录进栈成为运行时栈新的栈顶。 每返回一层递归调用,就退栈一个工作记录。因为栈顶的工作记录必定是当前正在运行的递归函数的工作记录,所以栈顶的工作记录也称为活动记录。 6.5 递归算法的效率分析 斐波
您可能关注的文档
最近下载
- 2025年闽教版(2024)小学英语四年级上册(全册)教学设计(附目录P123).docx
- 人教版高中英语第三册Unit 1 FESTIVALS AND CELEBRATIONS教学设计.docx VIP
- 数据结构常用算法数据结构算法.pdf VIP
- 20世纪人类最伟大的100项科学发明.doc VIP
- 北师大版九年级上册数学第一次月考试卷及答案.docx VIP
- 脊柱外科进修汇报.pptx VIP
- 2025年必威体育精装版版个人征信报告(含水印)模板【可修改】 .pdf VIP
- 金刚砂地坪施工技术交底.pdf VIP
- 人教版英语2024七年级上册全册单元知识清单(背诵版).pdf VIP
- 股权设计与股权激励.pdf VIP
文档评论(0)