码迷,mamicode.com
首页 > 其他好文 > 详细

何为递归

时间:2019-05-13 14:00:41      阅读:94      评论:0      收藏:0      [点我收藏+]

标签:间接   ==   开始   是你   过程   过多   一个   存储   需要   

1.我们使用的词典,本身就是递归,为了解释一个词,需要使用更多的词。
当你查一个词,发现这个词的解释中某个词仍然不懂,于是你开始查这第二个词,可惜,第二个词里仍然有不懂的词,于是查第三个词,这样查下去,直到有一个词的解释是你完全能看懂的,那么递归走到了尽头,然后你开始后退,逐个明白之前查过的每一个词,最终,你明白了最开始那个词的意思。。。

2.天下有奇族人姓计,长生不老。一日其孙问其父:吾之18代祖名何?
其父不明,父问其父
其父不明,父问其父
其父不明,父问其父
其父不明,父问其父
...
晌后,其18代祖回其子:你猜
然其回其子:你猜
然其回其子:你猜
然其回其子:你猜
然其回其子:你猜
……
终,计姓末代孙知其18代祖名“你猜”

此乃,递归
3.什么是递归?这里有一个故事是这样说的:
从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚对小和尚说,从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚对小和尚说,从前有座山,山里有座庙,庙里有个老和尚和小和尚,老和尚对小和尚说...... 这就是递归

言归正传,递归的本质是一个过程或函数在定义时,出现直接或者间接调用自己的成分。
下面这个求 n! 的例子中,递归出口(确定递归什么时候结束)是fun(1)=1,递归体(确定递归求解时的递归关系)是fun(n)=n*fun(n-1),n>1。
int fun(int n){
    if(n==1)
        return 1;
    else
        return n*fun(n-1);
 }

求n! 的递归思路就是把 f(n)=n! 转化成 fun(n-1) ,再把 fun(n-1) 分解为 f(n-2) 来解决,依此类推直到每个问题都可以直接解决(分解到 fun(1) )。

递归体的一般格式:
f(sn)=g(f(si), f(si+1), …, f(sn-1), cj, cj+1, …, cm)
g是一个非递归函数,cj, cj+1, …, cm为常量

在递归调用的过程当中系统为每一层的返回点、局部量等开辟了栈来存储,而栈的空间是有限的,调用层次过多容易造成栈溢出。

 

何为递归

标签:间接   ==   开始   是你   过程   过多   一个   存储   需要   

原文地址:https://www.cnblogs.com/gulugulut/p/10856002.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!