解题思路:
第n年: | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
fn头牛? | 1 | 2 | 3 | 4 | 6 | 9 | 13 | 19 | 28 |
在列出这个序列的过程中,应当能找出规律。
以n=6为例,fn=9头牛可以分解为6+3,其中6是上一年(第5年)的牛,3是新生的牛(因为第3年有3头牛,这3头在第6年各生一头牛)。
我们可以得出这样一个公式:fn=fn-1+fn-3
再理解一下,fn-1是前一年的牛,第n年仍然在,fn-3是前三年那一年的牛,但换句话说也就是第n年具有生育能力的牛,也就是第n年能生下的小牛数。
编程序,求解这个公式就行了。
当然,第1-3年的数目,需要直接给出。
很像斐波那契数列,有不一样之处,道理、方法一样。其实,在编程之前,讲究先用这样的方式建模。
注意事项:
开始用这个出现了时间超时。。。
#include<stdio.h>
int fun(int n)
{
if(n>0 && n<=4) return n;
else
if(n>4) return fun(n-1)+fun(n-3);
}
int main()
{
int n;
while(~scanf("%d", &n))
{
if(n<=0) break;
else
printf("%d\n",fun(n));
}
return 0;
}
参考代码:
#include<stdio.h>
int main()
{
int n,i;
int buf[55] = {1,2,3,4};
for(i=4;i<=54;i++)
{
buf[i] = buf[i-1]+buf[i-3];
}
while(~scanf("%d", &n))
{
if(n<=0) break;
else
printf("%d\n",buf[n-1]);
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题10.4 (C语言代码)浏览:585 |
C语言程序设计教程(第三版)课后习题10.1 (Java代码)浏览:1431 |
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:464 |
简单的a+b (C语言代码)浏览:596 |
C语言程序设计教程(第三版)课后习题9.1 (C语言代码)浏览:681 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:397 |
循环入门练习6 (C语言代码)浏览:947 |
C语言程序设计教程(第三版)课后习题8.2 (C语言代码)浏览:1027 |
1074(纳闷了,答案错误,求指教)浏览:362 |
C二级辅导-公约公倍 (C语言代码)浏览:658 |