斐波那契数列的C语言多种实现方法(递归、循环、动态规划、矩阵乘法和公式法)

介绍

斐波那契数列是一个非常有趣的数列,它的每一项都是前两项的和,前两项分别为0和1。这个数列的前几项是:0、1、1、2、3、5、8、13、21、34、55、89、144、233、377、610、987、1597、2584、4181、6765。这个数列的公式可以表示为:

  • F0 = 0
  • F1 = 1
  • Fn = Fn-1 + Fn-2(n >= 2)

这个数列有许多有趣的性质,例如,两个连续的斐波那契数之比会收敛于黄金比例,约等于1.61803399。

在这篇博客中,我们将探讨如何使用C语言实现斐波那契数列,并讨论各种方法的时间复杂度。

递归实现

递归是最直观的方法,直接根据斐波那契数列的定义F(n) = F(n-1) + F(n-2)来实现。但是这种方法的时间复杂度是O(2^n),因为它会重复计算很多项,效率非常低。

#include<stdio.h>

// 斐波那契数列函数
int fibonacci(int n) {
    if(n == 0) {
        return 0;
    } else if(n == 1) {
        return 1;
    } else {
        return fibonacci(n-1) + fibonacci(n-2);
    }
}

int main() {
    int n;
    printf("请输入一个整数:");
    scanf("%d", &n);
    printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
    return 0;
}

循环实现

循环实现是一种更有效的方法,它使用两个变量来保存前两项,然后通过循环来计算第n项。这种方法的时间复杂度是O(n),效率比递归高很多。

#include<stdio.h>

// 斐波那契数列函数
int fibonacci(int n) {
    if(n <= 1) {
        return n;
    }
    int a = 0, b = 1;
    for(int i = 2; i <= n; i++) {
        int temp = a + b;
        a = b;
        b = temp;
    }
    return b;
}

int main() {
    int n;
    printf("请输入一个整数:");
    scanf("%d", &n);
    printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
    return 0;
}

动态规划实现

动态规划也是使用循环,但是它会把前n项都保存在一个数组中,这样就可以避免重复计算。这种方法的时间复杂度也是O(n),但是空间复杂度也是O(n),因为需要额外的空间来保存数组。

#include<stdio.h>

// 斐波那契数列函数
int fibonacci(int n) {
    int f[n+2];   // 1 extra to handle case, n = 0
    int i;
  
    // 0th and 1st number of the series are 0 and 1
    f[0] = 0;
    f[1] = 1;
  
    for (i = 2; i <= n; i++) {
        // Add the previous 2 numbers in the series and store it
        f[i] = f[i-1] + f[i-2];
    }
  
    return f[n];
}

int main () {
    int n;
    printf("请输入一个整数:");
    scanf("%d", &n);
    printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
    return 0;
}

矩阵乘法实现

斐波那契数列还可以通过矩阵乘法来计算。具体来说,斐波那契数列可以表示为一个2×2矩阵的n次幂。这种方法的时间复杂度是O(logn),但是实现起来比较复杂。

#include<stdio.h>

void multiply(int F[2][2], int M[2][2]);

void power(int F[2][2], int n);

// 斐波那契数列函数
int fibonacci(int n) {
    int F[2][2] = {{1,1},{1,0}};
    if (n == 0)
        return 0;
    power(F, n - 1);
    return F[0][0];
}

void multiply(int F[2][2], int M[2][2]) {
    int x =  F[0][0]*M[0][0] + F[0][1]*M[1][0];
    int y =  F[0][0]*M[0][1] + F[0][1]*M[1][1];
    int z =  F[1][0]*M[0][0] + F[1][1]*M[1][0];
    int w =  F[1][0]*M[0][1] + F[1][1]*M[1][1];
  
    F[0][0] = x;
    F[0][1] = y;
    F[1][0] = z;
    F[1][1] = w;
}

void power(int F[2][2], int n) {
    int i;
    int M[2][2] = {{1,1},{1,0}};
  
    // n - 1 times multiply the matrix to {{1,0},{0,1}}
    for (i = 2; i <= n; i++)
        multiply(F, M);
}

int main () {
    int n;
    printf("请输入一个整数:");
    scanf("%d", &n);
    printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
    return 0;
}

公式法实现

斐波那契数列实际上可以通过一个公式直接计算第n项,这个公式叫做Binet’s formula。但是这个公式涉及到无理数和四舍五入,所以在实际使用中可能会有精度问题。这种方法的时间复杂度是O(1),但是只适用于n较小的情况。

#include<stdio.h>
#include<math.h>

// 斐波那契数列函数
int fibonacci(int n) {
    double phi = (1 + sqrt(5)) / 2;
    return round(pow(phi, n) / sqrt(5));
}

int main () {
    int n;
    printf("请输入一个整数:");
    scanf("%d", &n);
    printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
    return 0;
}

结论

以上就是使用C语言实现斐波那契数列的几种方法,包括递归、循环、动态规划、矩阵乘法和公式法。每种方法都有其优点和缺点,适用于不同的情况。在实际编程中,我们需要根据具体的需求和条件来选择最合适的方法。希望这篇博客对你有所帮助!

版权声明:本文为博主作者:嵌入式领域爱好者原创文章,版权归属原作者,如果侵权,请联系我们删除!

原文链接:https://blog.csdn.net/m0_46359684/article/details/134768719

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
心中带点小风骚的头像心中带点小风骚普通用户
上一篇 2024年4月22日
下一篇 2024年4月22日

相关推荐