千家信息网

什么是js递归函数调用

发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,这篇文章主要介绍"什么是js递归函数调用",在日常操作中,相信很多人在什么是js递归函数调用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"什么是js递归函数调用"的疑惑
千家信息网最后更新 2024年12月13日什么是js递归函数调用

这篇文章主要介绍"什么是js递归函数调用",在日常操作中,相信很多人在什么是js递归函数调用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"什么是js递归函数调用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

  递归调用是一种特殊的嵌套调用,是某个函数调用自己或者是调用其他函数后再次调用自己的,只要函数之间互相调用能产生循环的则一定是递归调用,递归调用一种解决方案,一种是逻辑思想,将一个大工作分为逐渐减小的小工作,比如说一个和尚要搬50块石头,他想,只要先搬走49块,那剩下的一块就能搬完了,然后考虑那49块,只要先搬走48块,那剩下的一块就能搬完了,递归是一种思想,只不过在程序中,就是依靠函数嵌套这个特性来实现了。

  递归调用基本信息

  定义

  递归调用就是在当前的函数中调用当前的函数并传给相应的参数,这是一个动作,这一动作是层层进行的,直到满足一般情况的的时候,才停止递归调用,开始从最后一个递归调用返回。

  英文

  recursiveinvocation

  函数模型

  fun(形参){

  fun(参数值1)//第一次递归调用

  fun(参数值2)//第二次递归调用

  递归调用举例

  C语言中的递归

  计算阶乘的代码

  longfact(longn)

  {

  if(n==0||n==1)return1L;

  elsereturnn*fact(n-1);

  }

  这个函数叫做fact,它自己调用自己,这个就是一个典型的递归调用,调用过程类似一个栈。

  注:主调函数又是被调函数。执行递归函数将反复调用其自身。每调用一次就进入新的一层。

  intf(intx)

  {

  inty;

  z=f(y);

  returnz;

  }这个函数是一个递归函数。但是运行该函数将无休止地调用其自身,这当然是不正确的。为了防止递归调用无终止地进行,必须在函数内有终止递归调用的手段。常用的办法是加条件判断,满足某种条件后就不再作递归调用,然后逐层返回。下面举例说明递归调用的执行过程。

  注:链表在某种程度上就是递归的调用.

  Pascal中的递归

  const

  z=10000;

  var

  a:array[0..z+1]ofinteger;

  n,j,i,k:longint;

到此,关于"什么是js递归函数调用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0