当前位置:   article > 正文

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

斐波那契数列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),因为它会重复计算很多项,效率非常低。

  1. #include<stdio.h>
  2. // 斐波那契数列函数
  3. int fibonacci(int n) {
  4. if(n == 0) {
  5. return 0;
  6. } else if(n == 1) {
  7. return 1;
  8. } else {
  9. return fibonacci(n-1) + fibonacci(n-2);
  10. }
  11. }
  12. int main() {
  13. int n;
  14. printf("请输入一个整数:");
  15. scanf("%d", &n);
  16. printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
  17. return 0;
  18. }

循环实现

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

  1. #include<stdio.h>
  2. // 斐波那契数列函数
  3. int fibonacci(int n) {
  4. if(n <= 1) {
  5. return n;
  6. }
  7. int a = 0, b = 1;
  8. for(int i = 2; i <= n; i++) {
  9. int temp = a + b;
  10. a = b;
  11. b = temp;
  12. }
  13. return b;
  14. }
  15. int main() {
  16. int n;
  17. printf("请输入一个整数:");
  18. scanf("%d", &n);
  19. printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
  20. return 0;
  21. }

动态规划实现

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

  1. #include<stdio.h>
  2. // 斐波那契数列函数
  3. int fibonacci(int n) {
  4. int f[n+2]; // 1 extra to handle case, n = 0
  5. int i;
  6. // 0th and 1st number of the series are 0 and 1
  7. f[0] = 0;
  8. f[1] = 1;
  9. for (i = 2; i <= n; i++) {
  10. // Add the previous 2 numbers in the series and store it
  11. f[i] = f[i-1] + f[i-2];
  12. }
  13. return f[n];
  14. }
  15. int main () {
  16. int n;
  17. printf("请输入一个整数:");
  18. scanf("%d", &n);
  19. printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
  20. return 0;
  21. }

矩阵乘法实现

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

  1. #include<stdio.h>
  2. void multiply(int F[2][2], int M[2][2]);
  3. void power(int F[2][2], int n);
  4. // 斐波那契数列函数
  5. int fibonacci(int n) {
  6. int F[2][2] = {{1,1},{1,0}};
  7. if (n == 0)
  8. return 0;
  9. power(F, n - 1);
  10. return F[0][0];
  11. }
  12. void multiply(int F[2][2], int M[2][2]) {
  13. int x = F[0][0]*M[0][0] + F[0][1]*M[1][0];
  14. int y = F[0][0]*M[0][1] + F[0][1]*M[1][1];
  15. int z = F[1][0]*M[0][0] + F[1][1]*M[1][0];
  16. int w = F[1][0]*M[0][1] + F[1][1]*M[1][1];
  17. F[0][0] = x;
  18. F[0][1] = y;
  19. F[1][0] = z;
  20. F[1][1] = w;
  21. }
  22. void power(int F[2][2], int n) {
  23. int i;
  24. int M[2][2] = {{1,1},{1,0}};
  25. // n - 1 times multiply the matrix to {{1,0},{0,1}}
  26. for (i = 2; i <= n; i++)
  27. multiply(F, M);
  28. }
  29. int main () {
  30. int n;
  31. printf("请输入一个整数:");
  32. scanf("%d", &n);
  33. printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
  34. return 0;
  35. }

公式法实现

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

  1. #include<stdio.h>
  2. #include<math.h>
  3. // 斐波那契数列函数
  4. int fibonacci(int n) {
  5. double phi = (1 + sqrt(5)) / 2;
  6. return round(pow(phi, n) / sqrt(5));
  7. }
  8. int main () {
  9. int n;
  10. printf("请输入一个整数:");
  11. scanf("%d", &n);
  12. printf("斐波那契数列的第%d项为:%d\n", n, fibonacci(n));
  13. return 0;
  14. }

结论

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/434052
推荐阅读
相关标签
  

闽ICP备14008679号