收藏 分享(赏)

呈现递归算法的思想及举例说明.doc

上传人:yjrm16270 文档编号:7705185 上传时间:2019-05-24 格式:DOC 页数:3 大小:23.50KB
下载 相关 举报
呈现递归算法的思想及举例说明.doc_第1页
第1页 / 共3页
呈现递归算法的思想及举例说明.doc_第2页
第2页 / 共3页
呈现递归算法的思想及举例说明.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、如何呈现递归算法的思想及举例说明高密市康成中学 陈飞鹏 2009 年 7 月 22 日 23:09 浏览:239 专家浏览:0 | 评论: 7 专家评论:0孟凡桥于 09-7-23 21:49 推荐总结了递归算法的特点、定义等,例子列举的简洁,适当,值得学习。一、递归算法的定义递归算法是一种直接或者间接地调用自身的算法。在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往使算法的描述简洁而且易于理解。 二、递归算法的特点递归过程一般通过函数或子过程来实现。递归算法在函数或子过程的内部,直接或者间接地调用自己的算法。递归算法的实质:是把问题转化为规模缩小了的同类问题的子问题。然后递归

2、调用函数(或过程)来表示问题的解。三、递归算法解决问题的特点:(1) 递归就是在过程或函数里调用自身。(2) 在使用递增归策略时,必须有一个明确的递归结束条件,称为递归出口。(3) 递归算法解题通常显得很简洁,但递归算法解题的运行效率较低。所以一般不提倡用递归算法设计程序。(4) 在递归调用的过程当中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等,所以一般不提倡用递归算法设计程序。递归算法所体现的“重复”一般有三个要求:一是每次调用在规模上都有所缩小(通常是减半);二是相邻两次重复之间有紧密的联系,前一次要为后一次做准备(通常前一次的输出就作为后一次的输入);三是在

3、问题的规模极小时必须用直接给出解答而不再进行递归调用,因而每次递归调用都是有条件的(以规模未达到直接解答的大小为条件),无条件递归调用将会成为死循环而不能正常结束四、下面我们用 c 语言举俩个例子来对递归算法进行一下演绎:1、有一个农场在第一年的时候买了一头刚出生牛,这头牛在第四年的时候就能生一头小牛,以后每年这头牛就会生一头小牛。这些小牛成长到第四牛又会生小牛,以后每年同样会生一头牛,假设牛不死,如此反复。请问 50 年后,这个农场会有多少头牛? 首先定义最终终止条件 f(4)=1; 然后定义递归公式中 f(n)=f(n-1)+f(n-3)。 #includeint fn(int a);vo

4、id main()int i;i = fn(20);printf(“%dn“,i);int fn(int a) if (a0)return 1; else if(a=4)a = fn(a-1) + fn(a-3);return a;2、有个莲花池里起初有一只莲花,每过一天莲花的数量就会翻一倍。假设莲花永远不凋谢,30 天的时候莲花池全部长满了莲花,请问第 23 天的莲花占莲花池的几分之几? 首先定义最终终止条件 f(1)=1; 然后定义递归公式中 f(n)=f(n-1)*2。 #includeint fn(int a);void main()int a;int b;double c;a = fn(30);b = fn(23);c = (double)b/a;printf(“%.20lfn“,c);int fn(int a)if(a = 1)return 1;elsea = fn(a-1)*2;return a;

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报