母牛的故事(PAT)

1.题目描述

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

2.输入描述:

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

3.输出描述:

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

4.输入例子:

2
4
5

5.输出例子:

2
4
6

6.解题思路:

类似于斐波那契数列,我们只需要找出规律即可,
如果单纯算出前几项,我们很难发现规律,但我们根据题意可知,每头小母牛在第四个年头开始也生小母牛,所以规律在于4个年头的循环
前四年我们可知所以小母牛都是由一头母牛所生,而在四年后,小母牛也开始陆续开始生小母牛,也就是第n年的母牛数量=《初始母牛所生的数量》+《新生母牛所生小母牛》=《初始母牛n-1年所生的数量》+《初始母牛n-3年所生的数量》
<mark>该公式的推导思想与斐波那契数列一模一样,我们可以先用递归的思想画出二叉树,然后再用非递归的方法推导,这样会好理解些。</mark>

7.源代码:

#include<stdio.h>
int main()
{ 
	int i,n,num[60];
	num[1]=1;
	num[2]=2;
	num[3]=3;
	num[4]=4;
	for(i=5;i<=56;i++)
		num[i]=num[i-1]+num[i-3];
	while(scanf("%d",&n)!=-1)
	{
		printf("%d\n",num[n]);
	}
	return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
frutiger:逆天,我家就安阳的,这hr咋能说3k的,你送外卖不比这工资高得多?还说大厂来的6k,打发叫花子的呢?这hr是怎么做到说昧良心的话的
找工作时遇到的神仙HR
点赞 评论 收藏
分享
05-22 12:44
已编辑
门头沟学院 golang
点赞 评论 收藏
分享
07-02 10:44
门头沟学院 C++
码农索隆:太实诚了,告诉hr,你能实习至少6个月
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务