题目描述
有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?
输入
输入数据由多个测试实例组成,每个测试实例占一行,包括一个整数n(0<n<55),n的含义如题目中描述。
n=0表示输入数据的结束,不做处理。
输出
对于每个测试实例,输出在第n年的时候母牛的数量。
每个输出占一行。
样例输入
2
4
5
0
样例输出
2
4
6
题解
注意:每头母牛每年年初生一头小牛;每头小牛经过4年成长期后,在第4年年初生产小牛。
根据上图找规律可得:
1.前4年的牛的总数=年份,即a[i] = i (0<i<=4)
;
2.第5年开始牛的总数=该年前第1年的牛的总数+该年前第3年的牛的总数,即a[i] = a[i-1] + a[i-3] (4<i<55)
代码(递归):
//1004母牛的故事
//2 3 4 6 9 13
#include<stdio.h>
int fun