问答详情
源自:5-8 递归函数(二)

请问一下,到底哪里错了

#include <stdio.h>
int getPeachNumber(n)
{
    int num;    //定义所剩桃子数
    if(n==10)
    {
       printf 1;       //递归结束条件
    }
    else
    {
        num = getPeachNumber(n+1)+1*2;   //这里是不应该用递归呢?
        printf("第%d天所剩桃子%d个\n", n, num); //天数,所剩桃子个数
    }
    return num;
}
int main()
{
    int num = getPeachNumber(1);
    printf("猴子第一天摘了:%d个桃子。\n", num);
    return 0;
}

提问者:菲尔活该 2015-11-18 23:58

个回答

  • 一梦到红楼
    2015-11-19 00:50:27
    已采纳

     printf 1;       //递归结束条件                这一行错了,应该是return 1;表示结束了递归。

        num = getPeachNumber(n+1)+1*2;   //这里是不应该用递归呢?        这一行也错了,num数量的计算是【(现在剩的+1)*2】是前一天剩的,再仔细想想是不是算式写错了。