递归思想和实例
来源:互联网 发布:java可变长参数 使用 编辑:程序博客网 时间:2024/06/06 12:34
先给一个简单的阶乘例子:
public static int getDg(int x){ System.out.println(x); if (x==1) { return 1; } if (x<4) {return x * getDg(x-1); } else {return x * getDg(x-1); } }
很多人对递归的理解不太深刻。一直就停留在“自己调用自己”的程度上。这其实这只是递归的表象(严格来说连表象都概括得不全面,因为除了“自己调用自己”的递归外,还有交互调用的递归)。而递归的思想远不止这么简单。
递归,并不是简单的“自己调用自己”,也不是简单的“交互调用”。它是一种分析和解决问题的方法和思想。简单来说,递归的思想就是:把问题分解成为规模更小的、具有与原问题有着相同解法的问题。比如二分查找算法,就是不断地把问题的规模变小(变成原问题的一半),而新问题与原问题有着相同的解法。
有些问题使用传统的迭代算法是很难求解甚至无解的,而使用递归却可以很容易的解决。比如汉诺塔问题。但递归的使用也是有它的劣势的,因为它要进行多层函数调用,所以会消耗很多堆栈空间和函数调用时间。
既然递归的思想是把问题分解成为规模更小且与原问题有着相同解法的问题,那么是不是这样的问题都能用递归来解决呢?答案是否定的。并不是所有问题都能用递归来解决。那么什么样的问题可以用递归来解决呢?一般来讲,能用递归来解决的问题必须满足两个条件:
- 可以通过递归调用来缩小问题规模,且新问题与原问题有着相同的形式。
- 存在一种简单情境,可以使递归在简单情境下退出。
如果一个问题不满足以上两个条件,那么它就不能用递归来解决。
为了方便理解,还是拿斐波那契数列来说下:求斐波那契数列的第N项的值。
这是一个经典的问题,说到递归一定要提到这个问题。斐波那契数列这样定义:f(0) = 0, f(1) = 1, 对n > 1, f(n) = f(n-1) + f(n-2)
这是一个明显的可以用递归解决的问题。让我们来看看它是如何满足递归的两个条件的:
- 对于一个n>2, 求f(n)只需求出f(n-1)和f(n-2),也就是说规模为n的问题,转化成了规模更小的问题;
- 对于n=0和n=1,存在着简单情境:f(0) = 0, f(1) = 1。
因此,我们可以很容易的写出计算费波纳契数列的第n项的递归程序:
int fib(n){ if(n == 0) return 0; else if(n == 1) return 1; else return f(n-1) + f(n-2);}
在编写递归调用的函数的时候,一定要把对简单情境的判断写在最前面,以保证函数调用在检查到简单情境的时候能够及时地中止递归,否则,你的函数可能会永不停息的在那里递归调用了。
延伸阅读
此文章所在专题列表如下:
- 漫谈递归:递归的思想
- 漫谈递归:递归需要满足的两个条件
- 漫谈递归:字符串回文现象的递归判断
- 漫谈递归:二分查找算法的递归实现
- 漫谈递归:递归的效率问题
- 漫谈递归:递归与循环
- 漫谈递归:循环与迭代是一回事吗?
- 递归计算过程与迭代计算过程
- 漫谈递归:从斐波那契开始了解尾递归
- 漫谈递归:尾递归与CPS
- 漫谈递归:补充一些Continuation的知识
- 漫谈递归:PHP里的尾递归及其优化
- 漫谈递归:从汇编看尾递归的优化
相关链接:http://www.nowamagic.net/librarys/veda/detail/2315
- 递归思想和实例
- 九、递归和分治思想
- 7、递归思想和迭代思想(递推思想)
- 文件和文件夹重命名---递归思想
- 递归和分治思想 (上)
- (黑马程序员)递归思想和及其应用
- 专注于<递归算法和分治思想>
- 学习笔记之递归和分治思想
- 简单二分查找和递归的思想
- PHP 递归和递推思想
- 快速排序 : 分治和递归思想
- 递归和分治思想及其应用
- 3 递归和分治的思想
- 迭代和递归基本思想
- 递归思想
- 递归思想
- 递归思想
- 递归思想
- 数据透视表 笔记
- 哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)D 数圈圈【DFS||数位DP】
- Android踩坑日记:android7.0动态相机权限
- 《Java并发编程的艺术》第四章——Java并发编程基础
- ZooKeeper 原理及其在 Hadoop 和 HBase 中的应用
- 递归思想和实例
- linux wget 命令用法详解(附实例说明)
- 浅谈Java中的hashcode方法
- Python入门自检
- 深耕网站安全防护技术研究的智恒再获奖项
- hexo创建新博客后自动打开
- solr6.X 404 403 问题总结
- Unity2017.3来了!洪流学堂第一时间送上更新日志简报
- 『React 开发』学习用 Ant Design 做后台系统