zoukankan      html  css  js  c++  java
  • js 递归

    一、知识说明

    function fun()

    {

        // 自己调用自己,称为递归调用

        fun();

        console.log("m2");

    }

    fun();

    二、函数+变量

    // 用递归 来求 5 的阶乘

    // n! = n * (n-1)!

    // 定义一个函数,用于求 n 的阶乘

    function func(n)

    {

        if (n == 1)

        {

            return 1;

        }

        // func(n-1) 因为传递的参数是 n-1,那么就是求 (n-1) 的阶乘

        return n * func(n-1);

    }

    console.log(     func(5)   );

    三、函数+函数

    //斐波拉契题(兔子生兔子题目)--从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少

    // 产量分析:1, 1, 2, 3, 5, 8, 13, 21 。。。

    // 第n个月的兔子总数  =  第n-1个月的兔子总数 + 第n-2个月的兔子总数

    // 问题: 求任意月兔子的总数

    function func( n )

    {

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

        {

            return 1;

        }

        return func(n-1) + func(n-2);

    }

    var a = func(22);

    console.log(a);

    //递归练习题:求任意数字的两两相加的和

                function getSum(n){
                    if (n === 1){
                        return 1;
                    }
                    return n + getSum (n-1);
                }
                console.log(getSum(5))



                function getSum(n){
                    if (n === 1){
                        return 1;
                    }
                    return n * getSum (n-1);
                }
                console.log(getSum(5))
  • 相关阅读:
    lua 5.3最简单plugin编写
    CMake for MFC example
    写了个自动生成vcxproj的程序
    kindle試玩
    解放双手:如何在本地调试远程服务器上的Node代码
    PM2实用入门指南
    Express使用手记:核心入门
    Node服务一键离线部署
    fis-receiver:一行命令将项目部署到远程服务器
    Reflux系列01:异步操作经验小结
  • 原文地址:https://www.cnblogs.com/ccnNL/p/8126764.html
Copyright © 2011-2022 走看看