斐波那契数列的递归和非递归解法

Posted 等风来

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了斐波那契数列的递归和非递归解法相关的知识,希望对你有一定的参考价值。

//递归解法
function fib(n){
    if(n < 1){
        throw new Error(‘invalid arguments‘);
    }
    if(n == 1 || n == 2){
        return 1;
    }
    return fib(n - 1) + fib(n - 2);
}
//非递归解法
function fib(n){
    if(n < 1){
        throw new Error(‘invalid arguments‘);
    }
    if(n == 1 || n == 2){
        return 1;
    }
    var a = 1,
        b = 1,
        res = 0;
    for(var i=3;i<=n;i++){
        res = a + b;
        a = b;
        b = res;
    }
    return res;
}

 

以上是关于斐波那契数列的递归和非递归解法的主要内容,如果未能解决你的问题,请参考以下文章

递归和非递归方法实现斐波那契

斐波那契数列递归解法与循环解法

斐波那契数列的两种实现(递归和非递归)

用递归和非递归的方法输出斐波那契数列的第n个元素(C语言实现)

10斐波那契数列

斐波那契数列