您现在的位置:
软界网
>
技术中心
>
软件开发
>
C/C++
> 技术显示
操作系统
|
办公软件
|
实用工具
|
网络管理
|
软件开发
|
WEB开发
|
软件工程
|
数据库
|
设计在线
|
信息安全
|
行业信息化
|
管理信息化
|
移动开发
数据结构学习(C++)之递归
2003-10-16 17:05:00 网友评论 阅读次数
点此评论
看过这样一道题,问,“
程序
结构化
设计
的三种基础结构,顺序、选择、循环是不是必须的?”当然,你知道这样一个论断,只要有这三种就足够了;但是能不能更少呢?答案是“可以”,原因就是递归能取代循环的作用,例如下面的对一个数组里面元素求和的函数:
float rsum (float a[], const int n)
{
if (n <= 0) return 0;
else return rsum(a, n – 1) + a[n – 1];
}
实际上就是:
sum = 0;
for (int i = 0; i < n; i++) sum += a[i];
但实际的情况是,任何的一种语言里面都有循环结构,但不是任何的语言都支持递归;套用一句话,递归是万能的,但没有递归不是万万不能的。然而,我看到现在的某些人,不管什么问题都要递归,明明循环是第一个想到的方法,偏偏费尽脑筋去寻找递归算法。对此,我真的不知道该说什么。
递归是算法吗
经常的看到“递归算法”、“非递归算法”,这种提法没有语义上的问题,并且我自己也这样用——递归的算法。但这也正说明了,递归不是算法,他是一种思想,正是因为某个算法的指导思想是递归的,所以才被称为递归算法;而一个有递归算法的问题,当你不使用递归作为指导思想,这样得到的算法就是非递归算法。——而对于循环能处理的问题,都有递归解法,在这个意义上说,循环算法都可以称为非递归算法。
我在这咬文嚼字没什么别的意思,只是想让大家知道,能写出什么样的算法,关键是看你编写算法时的指导思想。如果一开始就想到了循环、迭代的方法,你再费心耗神去找什么递归算法——即使找到了一种看似“简洁”的算法,由于他的低效实际上还是废物——你还在做这种无用功干什么?典型的学究陋习。如果你仅仅想到了递归的方法,现在你想用栈来消解掉递归,你做的工作仅仅是把系统做的事自己做了,你又能把效率提高多少?盲目的迷信消解递归就一定能提高效率是无根据的——你做的工作的方法如果不得当的话,甚至还不如系统原来的做法。
从学排列组合那天开始,我所知道的阶乘就是这个样子n! = 1×2×……n。如果让我来写阶乘的算法,我也只会想到从1乘到n。再如,斐波那契数列,如果有人用自然语言描述的话,一定是这样的,开始两项是0、1,以后的每项都是前面两项的和。所以让我写也只会得到“保存前两项,然后相加得到结果”的迭代解法。——现在只要是讲到递归几乎就有他们的登场,美其名曰:“定义是递归的,所以我们写递归算法”。我想问的是,定义的递归抽象是从哪里来的?显然阶乘的定义是从一个循环过程抽象来的,斐波那契数列的定义是个迭代的抽象。于是,我们先从一个本不是递归的事实抽象出一个递归的定义,然后我们说,“因为问题的定义是递归的,因此我们很容易写出递归算法”,接着说,“我们也能将这个递归算法转化为循环、迭代算法”,给人的感觉就像是1÷3=0.33……,0.33……×3=0.99……,然后我们花了好大的心智才明白1=0.99……。
还是有那么些人乐此不疲,是凡讲到递归就要提到这两个,结果,没有一个学生看到阶乘那样定义没有疑问的,没有一个对于那个递归的阶乘函数抱有钦佩之情的——瞎折腾什么呢?所以,如果要讲递归,就要一个令人信服的例子,而这个例子非汉诺塔莫属。
天极IT资讯短信服务
电脑
小技巧
资费:包月5元
手机:
介绍:细处着手,巧处用功。高手和菜鸟之间的差别就是:高手什么都知道,菜鸟知道一些。电脑小技巧收集最新奇招高招,让你轻松踏上高手之路。(首月免费)
共4页。
1
2
3
4
:
');
');
');
');
');
');}'); }//-->
相关文章
·
数据结构学习(C++)之排序
·
数据结构学习(C++)之稀疏矩阵
·
C语言学习中的四大难点
·
关于C++异常处理的心得体会
·
数据结构学习(C++)之二叉树
·
数据结构学习(C++)之单链表
最新更新
·
“自由连接”为主题的08SINOCES JBL展台
·
实景拍摄车进英国采集图片 谷歌被批“盗贼”
·
超值显卡添新丁 盈通3690龙翼版499元到货
·
求败而不败 祺祥HD3850独孤求败显卡卖699!
·
双核入门用户首选 航嘉BS3500电源值得信赖
·
质疑网店新规的合理性和合法性
');
'); }//-->
关注此文读者还看过
·
用C++控制DVD/CD驱动器的开关
·
C++中使用BHO来屏蔽特定网站
·
用托管C++监视Windows事件日志
·
使用C++异常来取代exit()函数
·
并非偏见 也驳“驳'C语言已经死了'”
·
浅薄与偏见 驳“C语言已经死了”
·
C语言已经死了,5个需要忘却它的理由
·
Intel C++ 9.0编译器优化效果测试
·
在C语言中实现动态分配二维数组
');}
网友关注
最新上市
编辑推荐
综合布线
条码设备
证卡打印机
条码打印机
录音电话
文章阅读排行
周排行
月排行
绿色时尚 一周D-Link无线路由器推荐
新架构新平台 编辑带你打造高端游戏新利器
腾讯QQ2008 正式版发布 新功能让你心动
速抢!惠普超人气6515b升级上阵 旋风压境
画面简化!PS2版《真三国无双5》亮相
揭秘《暗黑破坏神3》火爆真正原因
双核DDR3独显本再创新低 神舟F233T无敌3899
高频无线本W230R再升级 神舟12寸轻薄本暑促对决
小巧灵动!JVC 3CCD高清摄像机HD3跌破7K
2008绝无仅有 微星P45 Neo3-FR庆典价88元
绿色时尚 一周D-Link无线路由器推荐
近期DIY热点硬件大荟萃之每周硬件导购专题
新品推荐 索尼CR392双核独显本仅8650元
口袋里的移动世界 海尔X100“小得不简单”
F2光圈SWD配置 奥林巴斯14-35mm镜头详评
升级更全能 盈通9600GT游戏高手全能版评测
拍下清晰奥运瞬间!超高像素手机专项导购
三千五能装啥电脑?DX10游戏液晶装机方案
MP3高端机型 消费者关注度排行前三名
暑促大降价!ThinkPad全线笔记本狂跌实录
绿色时尚 一周D-Link无线路由器推荐
与你在一起 英特尔中国区总经理杨叙到访
网虫的DVD机 天敏炫影DMP100媒体播放器测试
四种方法实现文档双面打印
《QQ炫舞》专题-2008最浪漫的舞蹈网游
新品推荐 12英寸伸缩屏海尔VM便携本抵京城
低端用户看过来 8款不足400元实用主板导购
军容鼎盛!7款中端主流AMD 780G主板导购
拍好人物照就得用面部识别功能数码相机
全速运行DX10游戏 5000元双核液晶装机推荐
热点推荐
谁才是你的首选 近期市售P45主板抢先推荐
399元就能买到8600GT!铭鑫8600GTU测试
邀您同游台北电脑展 Computex 2008现场直击
中端性价比之王 小影霸GX5显卡详细评测
欢迎订阅天极网RSS聚合资讯:
http://www.yesky.com/index.xml
');