• 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))
  • 相关阅读:
    Thinkpad R400无线网络一个都不见了!
    如果使用安卓4.4的SD卡?
    如何使用安卓4.4的SD卡?
    在IAR使用FreeRTOS出现Error[Pa045]: function "XXX" has no prototype
    DSP5509的RTC实验-第3篇
    LWM2M简介-学习记录
    DSP5509的定时器实验-第2篇
    DSP5509的XF实验-第一篇
    华为LiteOS系统使用-任务调度函数-第一篇
    2017-12-24自选的股票之春秋航空
  • 原文地址:https://www.cnblogs.com/ccnNL/p/8126764.html
Copyright © 2020-2023  润新知