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

【题解】母牛的故事

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

【题目描述】

有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第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;
}


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

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

分享给朋友:

相关文章

【题解】牛的阵容

【题目描述】农民约翰雇一个专业摄影师给他的奶牛拍照。由于约翰的牛有很多品种,他喜欢他的照片包含每个品种至少一头牛。约翰的牛都站在数轴的不同地方,每一头牛由一个整数位置 X_i 以及整数品种编号 ID_...

2的幂次方表示

【题目描述】任何一个正整数都可以用2的幂次方表示。例如:137=27+23+20同时约定方次用括号来表示,即ab可表示为a(b)。由此可知,137可表示为:2(7)+2(3)+2(0)进一步:7=22...

【题解】Power Strings

【题目描述】给定若干个长度 ≤106 的字符串,询问每个字符串最多是由多少个相同的子字符串重复连接而成的。如:ababab 则最多有 3 个 ab 连接而成。【输入描述】输入若干行,每行有一...

【题解】取数

【题目描述】设有N 个正整数(1 <= N <= 50),其中每一个均是大于等于1、小于等于300的数。从这N个数中任取出若干个数(不能取相邻的数),要求得到一种取法,使得到的和为最大。例...

【题解】转换的问题

【题目描述】那么,问题来了:输入一个十进制数N,将它转换成R进制数输出。【输入描述】输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<&...

八皇后问题

八皇后问题

【题目描述】八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行...