循环、迭代、遍历和递归
浏览:4457次 出处信息
本想先找本算法和数据结构的书参考一下,但转念一想:不如考考自己的总结和逻辑表达能力。
loop、iterate、traversal和recursion这几个词是计算机技术书中经常会出现的几个词汇。众所周知,这几个词分别翻译为:循环、迭代、遍历和递归。乍一看,这几个词好像都与重复(repeat)有关,但有的又好像不完全是重复的意思。那么这几个词到底各是什么含义,有什么区别和联系呢?下面就试着解释一下。
- 循环(loop),指的是在满足条件的情况下,重复执行同一段代码。比如,while语句。
- 迭代(iterate),指的是按照某种顺序逐个访问列表中的每一项。比如,for语句。
- 遍历(traversal),指的是按照一定的规则访问树形结构中的每个节点,而且每个节点都只访问一次。
- 递归(recursion),指的是一个函数不断调用自身的行为。比如,以编程方式输出著名的斐波纳契数列。
有了以上定义,这几个概念之间的区别其实就比较清楚了。至于它们之间的联系,严格来讲,它们似乎都属于算法的范畴。换句话说,它们只不过是解决问题的不同手段和方式,而本质上则都是计算机编程中达成特定目标的途径。
建议继续学习:
- python编程细节──遍历dict的两种方法比较 (阅读:19005)
- 在C++中实现foreach循环,比for_each更简洁! (阅读:8632)
- PHP与递归Recursion (阅读:8248)
- 腾讯敏捷开发及快速迭代 (阅读:6518)
- for 循环为何可恨? (阅读:4461)
- C/C++循环获取文件中的每行数据(别以为很简单!) (阅读:3885)
- 递归并不一定非得是“自己调用自己的function” (阅读:3187)
- 小心递归次数限制 (阅读:3080)
- 最近几个容易错的地方总结(hash_map迭代删除,localtime(),线程状态) (阅读:3000)
- PHP正则之递归匹配 (阅读:2722)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:关于哈希map奇慢无比的原因定位
后一篇:如何给指定地址空间拍一个快照 >>
文章信息
- 作者:为之漫笔 来源: 为之漫笔
- 标签: 循环 迭代 递归 遍历
- 发布时间:2011-01-27 23:01:13
建议继续学习
近3天十大热文
- [47] IOS安全–浅谈关于IOS加固的几种方法
- [46] 图书馆的世界纪录
- [46] 如何拿下简短的域名
- [46] Oracle MTS模式下 进程地址与会话信
- [43] 【社会化设计】自我(self)部分――欢迎区
- [42] 读书笔记-壹百度:百度十年千倍的29条法则
- [41] android 开发入门
- [41] 界面设计速成
- [39] 视觉调整-设计师 vs. 逻辑
- [36] Go Reflect 性能