当前位置:首页 > 题解目录 > 正文内容

【题解】母牛的故事

亿万年的星光5年前 (2021-07-12)题解目录21086

【题目描述】

有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?

【输入描述】

输入数据由多个测试实例组成,每个测试实例占一行,包括一个整数n(0<n<55),n的含义如题目中描述。
n=0表示输入数据的结束,不做处理。

【输出描述】

对于每个测试实例,输出在第n年的时候母牛的数量。
每个输出占一行

【样例输入】

2
4
5
0

【样例输出】

2
4
6

【题目分析】

我们先列出一个表格,把每一年对应的母牛数量写出来。问题的关键分清每年牛的数量。确定数量后再推导规律。


表格参考下面:(大牛表示每年都可以生牛的牛,牛1表示大牛第二年的生的牛,牛2表示大牛第三年生的牛,牛3表示第4年生的牛)

年数
大牛牛1牛2牛3
总数
第一年10001

解释:第一年,只有1头母牛(根据测试样例中,第二年有2头,说明题目中说的年初是第二年年初,而不是第一年年初)

当第二年时:

年数大牛牛1牛2牛3总数
第二年11002

解释:大牛在第二年年初生了一头小牛。这时牛1还不到第四年,所以一共2头牛

当第三年时:

年数大牛牛1牛2牛3总数
第三年11103

解释:牛1才第二年,不能生小牛。大牛继续生小牛。所以一共3头牛。

当第四年时:

年数大牛牛1牛2牛3总数
第四年11114

解释:牛1是第三年,不能生小牛。牛2是第二年,不能生小牛。牛3是第一年,不能生小牛。所以一共4头牛。

当第五年时:

年数大牛牛1牛2牛3总数
第五年21114

也可以通过下面的图进行分析:(实线表示生育关系,虚线表示成长关系)

可以用下面这个表格来表示:

第 n年:12345678
f[n] 头牛:1
23469
1319

规律就是该年母牛的数量就是一年前的数量再加上三年前的数量,

用公式表示就是 f[n] = f[n-1] + f[n-3]

参考代码:

#include<iostream>
using namespace std;
int f[55]; 
int main()
{
    int n, i;
  	f[0]=0,f[1]=1,f[2]=2,f[3]=3;
    for (i = 4; i < 55; i++)
        f[i] = f[i - 1] + f[i - 3];
    while (1)  
    {	cin>>n;
		if(n==0){
			return 0
		} 
        cout << f[n] << endl;
    }
    return 0;
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    最大数max

    【题目描述】已知:m=max(a,b,c)max(a+b,b,c)×max(a,b,b+c)m=max(a,b,c)max(a+b,b,c)×max(a,b,b+c)输入a,b,c,求m。把求三个数的...

    【题解】公路乘车(动态规划)

    【题目描述】一个特别的单行街道在每公里处有一个汽车站。顾客根据他们乘坐汽车的公里使来付费。例如下表就是一个费用的单子。   没有一辆车子行驶超过10公里,一个顾客打算行驶n公里(1<...

    【题解】夹角

    【题目描述】这次童鞋们面临的问题是这样的:在一个平面内有两个点,求两个点分别和原点的连线的夹角的大小。注:夹角的范围[0,180],两个点不会在圆心出现。【输入描述】输入数据的第一行是一个数据T,表示...

    分数求和

    题目描述】输入n个分数并对他们求和,并用最简形式表示。所谓最简形式是指:分子分母的最大公约数为1;若最终结果的分母为1,则直接用整数表示。如: 5/6  、 10/3  均是最简形...

    CSPJ2022 乘方

    【题目描述】小文同学刚刚接触了信息学竞赛,有一天她遇到了这样一个题:给定正整数a和b,求ab的值是多少。ab即 b 个a相乘的值,例如23 即为3个2相乘,结果为2×2×2=8。“简单!”小...

    大象喝水

    【题目描述】上课的时候老师问了小蒜蒜和同学们一个问题:一只大象口渴了,要喝 20 升水才能解渴,但现在只有一个深 h 厘米,底面半径为 r厘米的小圆桶...