c++1055: 兔子繁殖问题 (递归调用)

问题示例:

题目描述

这是一个有趣的古典数学问题,著名意大利数学家Fibonacci曾提出一个问题:有一对小兔子,从出生后第3个月起每个月都生一对兔子。小兔子长到第3个月后每个月又生一对兔子。按此规律,假设没有兔子死亡,第一个月有一对刚出生的小兔子,问第n个月有多少对兔子?

输入

输入月数n(1<=n<=44)。

输出

输出第n个月有多少对兔子。

补充:(补充前7条示例)

输入        输出        
11
21
32
43
55
68
713

代码实现:

#include<iostream>
using namespace std;
#include<math.h>
int first(int &phase1,int &phase2,int &could_birth)
{
    phase1=phase1;
}
int second(int &phase1,int &phase2,int &could_birth)
{
    first(phase1,phase2,could_birth);
    phase2=phase1;
    phase1=0;

}
int third(int &phase1,int &phase2,int &could_birth)
{
    second(phase1,phase2,could_birth);
    could_birth=could_birth+phase2;
    phase2=0;
    phase1=phase1+could_birth;
}
int common(int n,int &phase1,int &phase2,int &could_birth)
{
    third(phase1,phase2,could_birth);
    n=n-3;
    for(int i=1;i<=n;i++)
    {
        could_birth=could_birth+phase2;
        phase2=phase1;
        phase1=could_birth;
    }


}
int main()
{
    int n;
    cin>>n;
    int phase1=1;
    int phase2=0;
    int could_birth=0;

    int amount;
    if(n==1)
    {
       first(phase1,phase2,could_birth);
    }
     else if(n==2)
    {
       second(phase1,phase2,could_birth);

    }
    else if(n==3)
    {
       third(phase1,phase2,could_birth);

    }

    else{
        common(n,phase1,phase2,could_birth);
    }
    amount=phase1+phase2+could_birth;

    cout<<"phase1="<<phase1<<endl;
    cout<<"phase2="<<phase2<<endl;
    cout<<"could_birth="<<could_birth<<endl;
    cout<<"amount="<<amount<<endl;


}

代码剖析:

核心思想就是2年发育,第三年生,我们调用的时候需要用到递归思想,因为第三年的数量需要依赖于第二年的数量,第二年的数量也是在第一年的基础上才有的。

其中:

phase1:代表发育的第一年的小兔子的数量

phase2:代表发育的第二年的小兔子的数量

could_birth:代表可以生育的成人兔子的数量

(1)第一年的数量计算

int first(int &phase1,int &phase2,int &could_birth)
{
    phase1=phase1;
}

(2)第二年的数量计算

int second(int &phase1,int &phase2,int &could_birth)
{
    first(phase1,phase2,could_birth);
    phase2=phase1;
    phase1=0;

}

(3)第三年的数量计算

int third(int &phase1,int &phase2,int &could_birth)
{
    second(phase1,phase2,could_birth);
    could_birth=could_birth+phase2;
    phase2=0;
    phase1=phase1+could_birth;
}

(3)超过3年的数量计算

int common(int n,int &phase1,int &phase2,int &could_birth)
{
    third(phase1,phase2,could_birth);
    n=n-3;
    for(int i=1;i<=n;i++)
    {
        could_birth=could_birth+phase2;
        phase2=phase1;
        phase1=could_birth;
    }


}

效果:

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

还不秃顶的计科生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值