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

【题解】母牛的故事

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

【题目描述】

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


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

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

分享给朋友:

相关文章

素数个数

【题目描述】编程求2~n(n为大于2的正整数)中有多少个素数。【输入描述】输入n (2<= n <=50000)【输出描述】素数个数【输入样例】10【输出样例】4#include<i...

【题解】排队买票

【题目描述】有M个小孩到公园玩,门票是1元。其中N个小孩带的钱为1元,K个小孩带的钱为2元。售票员没有零钱,问这些小孩共有多少种排队方法,使得售票员总能找得开零钱。注意:两个拿一元零钱的小孩,他们的位...

猴子吃桃

【题目描述】猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。 第二天早上又将剩下的桃子吃掉一半,又多吃一个。以后每天早上都吃了前一天剩下的一半零一个。到第N天早上想再吃时...

【题解】队列问题

【题解】队列问题

4.队列问题(lru.cpp)【题目描述】有一个大小为n的页面缓存队列,初始为空,当计算机访问页面时,若缓存队列没有该页面,则加入到缓存队列中,若队列已满,则将删除访问时间最远的页面。有Q次询问,每次...

【题解】合唱队形

【题目描写】N位同学站成一排,音乐老师要请其中的(N−K)位同学出列,使得剩下的KK位同学排成合唱队形。合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2,…,K,他们的身高分别为T1,T...

【题解】踩方格

【题目描述】有一个方格矩阵,矩阵边界在无穷远处。我们做如下假设:a、每走一步时,只能从当前方格移动一格,走到某个相邻的方格上;b、走过的格子立即塌陷无法再走第二次;c、只能向北、东、西三个方向走;请问...