C语言使用普通循环方法和递归求斐波那契序列示例代码

Bena ·
更新时间:2024-11-10
· 533 次阅读

代码如下:
#include <stdio.h>

int fac(int x);

int main(void)
{
    int n;
    scanf("%d", &n);
    if (n == 1 || n == 2)
        printf("1\n");
    else if (n == 3)
        printf("2\n");
    else
    {
        int last = 1;
        int sum = 2;
        for (int i = 3; i < n; ++i)
        {
            int temp = sum;
            sum = sum + last;
            last = temp;
        }
        printf("循环求出斐波那契序列值:%d\n", sum);
    }
    int sum2 = fac(n);
    printf("递归求出斐波那契序列值:%d\n", sum2);
    return 0;
}


//递归

int fac(int x)
{
   static int f[50] = {1,1};
   if (x == 1 || x == 2)
      return f[x-1];
   return f[x-1] == 0 ?
          ( f[x-1] = fac(x-1) + fac(x-2) ) :
          f[x-1] ;
}

您可能感兴趣的文章:python实现斐波那契递归函数的方法python求斐波那契数列示例分享用Python实现斐波那契(Fibonacci)函数求斐波那契(Fibonacci)数列通项的七种实现方法java实现斐波那契数列的3种方法C++输出斐波那契数列的两种实现方法c#斐波那契数列(Fibonacci)(递归,非递归)实现代码php实现斐波那契数列的简单写法php处理斐波那契数列非递归方法python实现斐波那契数列的方法示例



方法 示例 循环 斐波那契 C语言 递归

需要 登录 后方可回复, 如果你还没有账号请 注册新账号