什么是递归函数? 怎样实现递归?
发布网友
发布时间:2022-04-23 10:01
我来回答
共5个回答
热心网友
时间:2022-04-29 12:35
递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。递归函数必须有结束条件。
当函数在一直递推,直到遇到墙后返回,这个墙就是结束条件。
所以递归要有两个要素,结束条件与递推关系。
递归有两个基本要素:
(1)边界条件:确定递归到何时终止,也称为递归出口。
(2)递归模式:大问题是如何分解为小问题的,也称为递归体。递归函数只有具备了这两个要素,才能在有限次计算后得出结果
在递归函数中,调用函数和被调用函数是同一个函数,需要注意的是递归函数的调用层次,如果把调用递归函数的主函数称为第0层,进入函数后,首次递归调用自身称为第1层调用;从第i层递归调用自身称为第i+1层。反之,退出第i+1层调用应该返回第i层。
一个递归函数的调用过程类似于多个函数的嵌套的调用,只不过调用函数和被调用函数是同一个函数。为了保证递归函数的正确执行,系统需设立一个工作栈。具体地说,递归调用的内部执行过程如下:
(1)运动开始时,首先为递归调用建立一个工作栈,其结构包括值参、局部变量和返回地址;
(2)每次执行递归调用之前,把递归函数的值参和局部变量的当前值以及调用后的返回地址压栈;
(3)每次递归调用结束后,将栈顶元
扩展资料:
递归就是某个函数直接或间接地调用了自身,这种调用方式叫做递归调用。说白了,还是函数调用。既然是函数调用,那么就有一个雷打不动的原则:所有被调用的函数都将创建一个副本,各自为调用者服务,而不受其他函数的影响。
你的ff函数,递归多少次,就有多少个副本,再利用内存的栈式管理,反向退出。这个最好找一下“栈”这方面的东西看看,挺容易的,就像子弹匣一样,先进后出。
从某种意义上说,这是不对的,因为就像刚才说的,一旦被调用,他将在内存中复制出一份代码,再被调用就再复制一份,换句话说,你可以吧同一个函数的多次调用理解称谓多个不同函数的一次调用,这样也会会简单些。
再说=1和=0是为什么退出。递归,很需要注意的就是死递归,也就是说,某一个函数进入了无限调用自身的情况,永无止境地消耗内存等资源,这在编程方面是一大忌。
但凡是递归的函数,一定会在某一个地方存在能够返回上一层函数的代码,否则必定死递归。ff函数中,那个else就是返回的出口,你可以这样想,如果没有那个if来进行判断,你递归到什么时候算完?ff是不是会一直调用自己。
因为一旦某个函数A中调用了函数B(或者自己),那么A中的代码会停在调用的位置,而转向B中去执行,同理,如果B又调用函数C,那么B又停在调用的位置,去执行C,如果无限调用,那么程序是永远不会结束的。
当然,也有这种情况,A调用B,然后继续自己的代码,不管B的死活,这种不在我们的讨论范围内,因为那牵扯到另一种编程方式:多线程。
参考资料:百度百科——递归函数
热心网友
时间:2022-04-29 13:53
递归就是本身调用自己。
如n!=n(n-1)!
你定义函数f(n)=nf(n-1)
而f(n-1)又是这个定义的函数。。这就是递归。
实现递归。简单说来从未知的推到已知的
如:3!=3*2!
2!=2*1!
1!=1(已知的)
然后从已知再返回调用给上一层。到你所要求的
1!=1(已知)
2!=2*1!=2*1=2
3!=3*2!=3*2=6
递归结束
热心网友
时间:2022-04-29 15:28
递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。递归函数必须有结束条件。
当函数在一直递推,直到遇到墙后返回,这个墙就是结束条件。
所以递归要有两个要素,结束条件与递推关系。
热心网友
时间:2022-04-29 17:19
比方说有一个函数叫max,它有两个参数,它的功能是求两个参数中较大的那个数。
例如:a=2,b=4, 则max(a,b)的值是4.
若现在有四个数a,b,c,d,利用max函数求出其中最大的数,怎么写呢?显然有很多方法,像是:max(max(a,b),max(c,d))
max(max(max(a,b),c),d)
不知道这个例子能否帮助你理解“递归”?
热心网友
时间:2022-04-29 19:44
递归函数的就是从一个作业的,然后归到一个男生,然后实现递归需要一些特殊条件。
什么是递归函数? 怎样实现递归?
递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。递归函数必须有结束条件。当函数在一直递推,直到遇到墙后返回,这个墙就是结束条件。所以递归要有两个要素,结束条件与递推关系。递归有两个基本要素:(1)边界条件:确定递归到何时终止,也称为...
什么是递归函数
递归函数是指一种特殊类型的函数,它会在其定义或实现中调用自身。递归是一种强大的编程技术,用于解决可以分解为更小的相似问题的问题。在递归函数中,通常会有一个或多个基本情况(base cases),这些是函数可以直接求解而无需进一步递归的情况。此外,还需要有递归情况(recursive cases),在这些情况下...
离散数学中的递归函数是什么意思?
递归函数是离散数学中的一种特殊函数,它通过调用自身来解决问题。递归函数通常具有两个基本要素:基本情况和递归情况。基本情况是指函数可以直接解决的问题,不需要进一步的递归调用。它是递归函数的终止条件,当满足基本情况时,函数将直接返回一个值。递归情况是指函数无法直接解决的问题,需要通过递归调用自...
递归函数的基本思想
递归函数的基本思想如下:递归就是方法自己调用自己 递归特点: 有临界点 当一个方法执行完毕,或者遇到retrun,就会返回,函数就是出栈。待求解问题的解 输入变量x的函数f(x),通过寻找函数g( ), 使得f(x) = g(f(x-1))。且已知f(0)的值, 就可以通过f(0)和g( )求出f(x)的值。扩展到多个...
递归函数是什么意思
递归函数是一种特殊的函数,它在函数定义中直接或间接地调用自身。这种函数在解决一些复杂问题时非常有用,比如需要重复执行相同任务的问题。递归函数通常有两个主要部分:一个是基线条件(base case),另一个是递归条件。基线条件通常是你期望函数直接返回的结果,而不需要进一步递归的情况。递归条件则是将...
什么是递归?递归有什么用?
递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于...
如何理解递归?
递归和迭代都是循环的一种。简单地说,递归是重复调用函数自身实现循环。迭代是函数内某段代码实现循环,而迭代与普通循环的区别是:循环代码中参与运算的变量同时是保存结果的变量,当前保存的结果作为下一次循环计算的初始值。递归循环中,遇到满足终止条件的情况时逐层返回来结束。迭代则使用计数器结束循环...
c语言中,什么是函数的递归,能举个例子么
所谓递归,说的简单点,就是函数自己调用自己,然后在某个特定条件下。结束这种自我调用。如果不给予这个结束条件,就成了无限死循环了。这样这个递归也就毫无意义了。如下面问题 1 1 2 3 5 8 13 21 ...n 分析可以看出, i 表示第几个数, n 表示该数的值 当i = 1 时, n = 1;当i ...
什么是递归
因此在很多函数编程语言中习惯用递归来实现循环。在支持自调用的编程语言中,递归可以通过简单的函数调用来完成。尾部递归是指递归函数在调用自身后直接传回其值,而不对其再加运算。尾部递归与循环是等价的,而且在一些语言可以被优化为循环指令。 因此,在这些语言中尾部递归不会占用调用堆栈空间。
什么是函数的递归调用?正确的函数递归条件是什么?并写一个简短的C语言...
递归就是函数自己调用自己的函数。其实递归函数的调用和其他一般函数调用没有什么区别,只是在形式上能够建立循环的逻辑调用。递归函数一定有个基本要求,就是肯定会满足某种条件,不再调用自身。(否则就无限递归,直到内存溢出)。例如,我们计算1到100的所有数相加。int addRecursion(int curTotle, int a...