尾递归

作者: 恒星的背影 | 来源:发表于2018-09-10 20:57 被阅读0次

    函数调用自身,称为『递归』;函数尾调用自身,称为『尾递归』

    由于递归需要保存大量调用帧,很消耗内存,容易发生 stack overflow,所以可以把普通的递归函数改为只存在一个调用帧的尾递归:

    普通写法:
    function factorial(n) {
      if (n === 1) return 1;
      return n * factorial(n - 1);
    }
    
    factorial(5) // 120
    
    改成:
    function factorial(n, total) {
      if (n === 1) return total;
      return factorial(n - 1, n * total);
    }
    
    factorial(5, 1) // 120
    

    相关文章

      网友评论

          本文标题:尾递归

          本文链接:https://www.haomeiwen.com/subject/orvjgftx.html