前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C编程练习001

C编程练习001

作者头像
正念君
发布2019-06-26 15:36:16
5420
发布2019-06-26 15:36:16
举报

1、题目

斐波纳契数列 1,1,2,3,5,8,13,21,34,55,89……这个数列则称为“斐波纳契数列”,其中每个数字都是“斐波纳契数”。

1.1 输入与输出

输入:一个整数N(N不能大于40)

输出:由N个“斐波纳契数”组成的“斐波纳契数列”。

1.2 样例输入与输出

样例输入:6

样例输出:1 1 2 3 5 8

2、代码

规律:当前数=前一个数+前前一个数。如2=1+1, 5=3+2, 8=5+3。有两种方法求解,一种方法是使用迭代法,另一种方法是通过递归的方式。完整代码如下:

/*******************************************************************************************************
** 题    目: 斐波纳契数列1,1,2,3,5,8,13,21,34,55,89……    
             这个数列则称为“斐波纳契数列”,其中每个数字都是“斐波纳契数”。
** 输    入: 一个整数N(N不能大于40)
** 输    出: 由N个“斐波纳契数”组成的“斐波纳契数列”。
** 样例输入:6    
** 样例输出:1 1 2 3 5 8 
********************************************************************************************************/
#include <stdio.h>
#include <string.h>

#define  Method   0  // 1:迭代法  0:递归法

#if Method 
// 方法一:迭代法
long fibonacci(int n)
{
    if (n <= 2)
    {
        return 1;
    }

    long result;
    long pre_result;
    long pre_pre_result;

    pre_result = pre_pre_result = 1;

    while (n > 2)
    {
        result = pre_result + pre_pre_result;
        pre_pre_result = pre_result;
        pre_result = result;
        n--;
    }

    return result;
}
#else 
// 方法二:递归法
long fibonacci(int n)
{
    if (n <= 2)
    {
        return 1;
    }

    return fibonacci(n - 1) + fibonacci(n - 2);

}
#endif

// 主函数
int main(void)
{
    int N;

    scanf("%d", &N);
    int i;

    for (i = 1; i <= N; i++)
    {
        printf("%ld ", fibonacci(i));
    }

    return 0;
}

运行结果为:

ZPSJ1A.png
ZPSJ1A.png
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-05-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、题目
    • 1.1 输入与输出
      • 1.2 样例输入与输出
      • 2、代码
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档