qq_36519547 2016-11-07 03:58 采纳率: 100%
浏览 1117

C语言问题新人求解 一道编程题目

输出[m,n]范围内的所有斐波那契(Fibonacci)数,m,n这两个数由键盘输入。
【提示】
1,1,2,3,5,8,13,21,34,……这是斐波那契(Fibonacci)数列的前几项。斐波那契数列的特点:前两项均为1,后面任意一项都是其前面两项之和。
本实验虽然只要求输出在[m,n]范围内的斐波那契数,但是依然需要从第1个Fibonacci数开始依次得到下一个,并判断是否是需要输出的那个。
不i要用太高深的程序,刚开始学

  • 写回答

7条回答 默认 最新

  • threenewbee 2016-11-07 04:05
    关注
     int f(int n)
    {
    if (n == 1 || n == 2) return 1;
    else return f(n - 2) + f(n - 1);
    }
    int main()
    {
    int m, n;
    scanf("%d %d", &m, &n);
    int i = 1;
    while (true)
    {
    int x = f(i);
    if (x >= m && x <=n) printf("%d ", x);
    if (x >= n) break;
    }
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料