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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

  2021-03-20 我要评论
想了解C语言使用普通循环方法和递归求斐波那契序列代码实例的相关内容吗,在本文为您仔细讲解C语言求斐波那契序列的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C语言,递归,斐波那契序列,下面大家一起来学习吧。

复制代码 代码如下:

#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] ;
}

猜您喜欢

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们