平平无奇的编程萌新 2022-03-05 18:51 采纳率: 95.2%
浏览 25
已结题

程序设计 -- 斐波那契数列

观察数列规律,求这个数列的第 n个数。11235813、…
输入格式
一行,一个整数 n
输出格式
一行, 一个整数
输入样例1
5
输出样例1
5
输入样例2
12
输出样例2
144
能改一改这下面吗
#include<iostream>
using namespace std;
int n;
int gcd(int n){
    if(n==1)    return 0;
    if(n==2)    return 1;
    else    return gcd(n-1)+gcd(n-2);
}
int main(){
    int n;
    cin>>n;
    cout<<gcd(n+1)<<endl;
    return 0;
}

  • 写回答

2条回答 默认 最新

  • 关注

    你这个可以把第一项改成1,提高速度
    而且 n 是全局变量,在 gcd() 和 main() 中又定义了
    修改代码如下:

    #include<iostream>
    using namespace std;
    int gcd(int n){
        if(n==1)    return 1;
        if(n==2)    return 1;
        else    return gcd(n-1)+gcd(n-2);
    }
    int main(){
        int n;
        cin>>n;
        cout<<gcd(n)<<endl;
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月14日
  • 已采纳回答 3月6日
  • 创建了问题 3月5日

悬赏问题

  • ¥15 孟德尔随机化结果不一致
  • ¥15 深度学习残差模块模型
  • ¥50 怎么判断同步时序逻辑电路和异步时序逻辑电路
  • ¥15 差动电流二次谐波的含量Matlab计算
  • ¥15 Can/caned 总线错误问题,错误显示控制器要发1,结果总线检测到0
  • ¥15 C#如何调用串口数据
  • ¥15 MATLAB与单片机串口通信
  • ¥15 L76k模块的GPS的使用
  • ¥15 请帮我看一看数电项目如何设计
  • ¥23 (标签-bug|关键词-密码错误加密)