Fibonacci序列

递归法:

long int fibonacci(int input)
{
    long int result;

    if (input >= 2) {
        result = fibonacci(input-1) + fibonacci(input-2);
    } else {
        switch (input) {
        case 0:
            result = 0;
            break;
        case 1:
            result = 1;
            break;
        }   
    }   
    return result;
}

循环法:

long long int fibonacci(int input)
{
    long long int f0 = 0;
    long long int f1 = 1;
    long long int f2;
    int i;

    switch (input) {
    case 0:
        return f0;
    case 1:
        return f1;
    }

    for (i = 2; i <= input; i++)
    {
        f2 = f0 + f1;
        f0 = f1;
        f1 = f2;
    }

    return f1;
}
方法 时间复杂度
递归法 O(2^n)
循环法 O(n)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容