使用两种方式实现斐波那契序列

 

/**
 * Created by wangbin on 2022/1/11.
*/

#include <stdio.h>
#include <time.h>

int fib(int n) {
    if (n <= 0) {
        return 0;
    } else if (n == 1) {
        return 1;
    } else {
        return fib(n - 1) + fib(n - 2);
    }
}

int fib2(int n) {
    int num1 = 1;
    int num2 = 1;
    int tmp = 0;
    int i;
    if (n <= 2) {
        return 1;
    } else {
        for (i = 3; i <= n ; i++) {
            tmp = num1 + num2;
            num1 = num2;
            num2 = tmp;
        }
        return tmp;
    }
}

int main(void) {
    double start, end;
    start = (double) clock();
    int res = fib2(20);
    printf("fib(20)=%d\n", res);
    end = (double) clock();
    printf("times=%.4f\n", (end - start));
    return 0;
}

 

posted @ 2022-01-11 11:25  Mars.wang  阅读(53)  评论(0编辑  收藏  举报