古典问题(兔子生崽):有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?(输出前40个月即可)
看到这个问题我们首先应该分析它的逻辑与思路,如何通过代码将这个问题实现 ?
我们根据题目来看:一月,二月都是一对兔子,三月兔子生兔子,变成了两对兔子,也就是四只兔子,四月是三对兔子(六只),五月五对(十只)..................
根据这个逻辑结构来看:
一月 + 二月 = 三月. 三月 + 四月 = 五月.
兔子的规律为数列1,1,2,3,5,8,13,21(是指兔子对数)....,即下个月是上两个月之和(从第三个月开始)。
接下来我们用代码来实现:
#include<stdio.h>
int main()
{
int tu1 = 1, tu2 = 1, i;
//一月二月兔子数量都为一对;
for (i = 1; i <= 20; i++)//循环设为20是因为有两个变量;
{
printf("%12d%12d", tu1, tu2);
if (i % 2 == 0) printf("\n");//打印格式
tu1 = tu1 + tu2;//前两月之和
tu2 = tu1 + tu2;//前两月之和\
//如果tu1是五月,那tu2就是六月
}
puts("");
printf("兔子四十个月后的数量:%d",tu2 * 2);
return 0;
}
运行结果如下:
这个运行结果有一点丑(不利于读者阅读)我们可以稍微修改一下:
好啦!!! 这样各位读者大人就可以看清楚了
具体问题我在代码上已经写的差不多啦,如果还有问题可以再评论区说出来,嘿嘿嘿