- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3.3栈与递归.ppt
3.3 栈与递归;递归算法的编写 1)将问题用递归的方式描述(定义) 2)根据问题的递归描述(定义)编写递归算法 问题的递归描述(定义) 递归定义包括两项 基本项(终止项):描述递归终止时问题的求解; 递归项:将问题分解为与原问题性质相同,但规模较小的问题; 例 阶乘函数 n!= 1* 2* 3* 4 * (n-1)* n n!递归定义 n!= 1 当 n=1 时 n!= n (n-1)! 当n 1 时;计算5的阶乘(5!=5X4X3X2X1) int f(int n) { if ( n = = 1) return (1); else return ( n * f(n-1)); };void print(int w) { int i; if ( w!=0) { print(w-1); for(i=1;i=w;++i) printf(“%3d,”,w); printf(“/n”); } };递归调用执行情况如下:;假设有A、B、C三个轴。在A上插有n个直径大小不同、以小到大编号为1、2、…、n的圆盘。现要求将A轴上的n个圆盘移至C轴上,并按同样顺序叠排。移动圆盘的规则为: 1)每次只能移动一个圆盘; 2)圆盘可以插在A、B、C的任意一个上; 3)任何时刻都不能将较大的圆盘压在较小的圆盘之上。 注: 这是一个经典的递归问题,n阶问题可以分解为n圆盘和n-1阶问题。;A;A B C;A B C;解决方法: n=1时,直接把圆盘从A移到C n1时,先把上面n-1个圆盘从A移到B,然后将n号盘从A移到C,再将n-1个盘从B移到C。 即把求解n个圆盘的Hanoi问题转化为求解n-1个圆盘的Hanoi问题,依次类推,直至转化成只有一个圆盘的Hanoi问题 执行情况: 递归工作栈保存内容:形参n,x,y,z和返回地址 返回地址用行编号表示; main() { int m; printf(Input number of disks”); scanf(%d,n); printf(”Steps : %3d disks”,n); hanoi(n,A,B,C); (0) } void hanoi(int n,char x,char y,char z) (1) { (2) if(n==1) (3) move(1,x,z); (4) else{ (5) hanoi(n-1,x,z,y); (6) move(n,x,z); (7) hanoi(n-1,y,x,z); (8) } (9) }; main() { int m; printf(Input the number of disks scanf(%d,m); printf(The steps to moving %3d hanoi(m,A,B,C); (0) } void hanoi(int n,char x,char y,char z) (1) { (2) if(n==1) (3) move(1,x,z); (4) else{ (5) hanoi(n-1,x,z,y); (6) move(n,x,z); (7) hanoi(n-1,y,x,z); (8) } (9) }; main() { int m; printf(Input the number of disks scanf(%d,m); printf(The steps to moving %3d hanoi(m,A,B,C); (0) } void hanoi(int n,char x,char y,char z) (1) { (2) if(n==1) (3) move(1,x,z); (4) else{ (5) hanoi(n-1,
您可能关注的文档
- (2005,广东,11,)如图7所示,某同学在做研究匀变速直.doc
- (2014.04.09)Photoshop图像处理课程教学研讨(文本).doc
- 00775历史教育学.doc
- 06637园林树木学.doc-高纲1165.doc
- 1.从屏幕上显示大写字母A.doc
- 1.关联(relating)关联表示两个类的对象之间存在某种语义.ppt
- 1.梳理高中数学课程中函数的结构脉络,并进.doc
- 1.职业院校管理工作主要参考点-附件1.doc
- 10100Mbps智能可堆叠交换机-慧聪网-中国领先.doc
- 11.2有穷自动机.ppt
- 浙江省温州市浙南名校联盟2025-2026学年高一上学期期中联考数学试题含解析.docx
- 26高考数学提分秘诀重难点34圆锥曲线中的定点、定值、定直线问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点35概率与统计的综合问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点31圆锥曲线中的切线与切点弦问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点30圆锥曲线中的弦长问题与长度和、差、商、积问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点29巧解圆锥曲线的离心率问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点28直线与圆的综合(举一反三专项训练)(全国通用)(含解析).docx
- 寡核苷酸药物重复给药毒性研究技术指南.docx
- 重组溶瘤腺病毒生产质量管理标准.docx
- 26高考数学提分秘诀重难点27直线与圆中常考的最值与范围问题(举一反三专项训练)(全国通用)(含解析).docx
有哪些信誉好的足球投注网站
文档评论(0)