| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2503 人关注过本帖
标题:用递归的一个兔子问题
只看楼主 加入收藏
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
结帖率:89.47%
收藏
已结贴  问题点数:20 回复次数:5 
用递归的一个兔子问题
TA家里养了一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月时就会变成成年兔子,从这个月起这对兔子每个月又生一对兔子,假如兔子都不死,问第n个月TA家里有多少只兔子?
Input
本体包含多组测试数据。以EOF或者-1结束。 每组测试数据包含一个正整数n,表示需要计算的月数。
Output
每组测试数据的结果占一行。 每行输出当月TA家中的兔子数量。
Sample Input 1
2
3
4
-1
Sample Output 1
2
4
6
Sample Input 2
2
3
4

Sample Output 2
2
4
6
搜索更多相关主题的帖子: 小兔子 正整数 
2016-12-05 16:58
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
#include<stdio.h>
int count(int n);
int main()
{
    int n;
    while(scanf("%d",&n)!=-1||scanf("%d",&n)!=EOF)
    {
        printf("%d\n",count(n));
    }   
    return 0;
}
int count(int n)
{
    if(n<=2)
    return 2;
    else
    return count(n-1)+count(n-2);
}
这是我写的代码,但是就是不能终止,为什么?
2016-12-05 16:58
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:20 
程序代码:
int main()
{
    int n;
    while (scanf("%d", &n) != EOF)
    {
        if (n == -1)
        {
            break;
        }
        printf("%d\n", count(n));
    }
    return 0;
}
2016-12-05 17:20
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
收藏
得分:0 
删除

[此贴子已经被作者于2016-12-5 17:26编辑过]


早知做人那么辛苦!  当初不应该下凡
2016-12-05 17:23
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 4楼 炎天
删除是什么意思?
2016-12-05 17:30
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 3楼 grmmylbs
原来可以这样写,理解了!谢谢!
2016-12-05 17:30
快速回复:用递归的一个兔子问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023453 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved