不知道程序哪错了

来源:5-8 递归函数(二)

weixin_慕后端5085378

2020-04-08 15:19

#include <stdio.h>

int getPeachNumber(n)

{

    int num;    //定义所剩桃子数

    if(n==10)

    {

       return 1;     //递归结束条件

    } 

    else

    {

        num = getPeachNumber(n)-n/2-1;   //这里是不应该用递归呢?

        printf("第%d天所剩桃子%d个\n",n,num); //天数,所剩桃子个数

    }

    return num;

}

int main()

{

    int num = getPeachNumber(1);

    printf("猴子第一天摘了:%d个桃子。\n", num);

    return 0;

}

求大神,这个程序有错但是他说我编译成功了,哪里错了?

写回答 关注

1回答

  • weixin_慕姐5388646
    2020-04-10 23:27:46
    已采纳

    num = getPeachNumber(n)-n/2-1; 这个递归条件有问题。

    正确的应该是这样:num = (getPeachNumber(n+1)+1)*2;

    这是从第10天往后倒推的递归。第10天剩一个,第9天剩(第十天剩的个数+1)*2 。然后再算第八天,第七天... 最后算到第一天。剩的个数我们用函数表示f(x),这样,f(9)=(f(10)+1)*2.

    梁炯民21物...

    是不是后面就是f(8)=(f(9)+1)*2

    2021-12-13 22:27:24

    共 2 条回复 >

C语言入门

C语言入门视频教程,带你进入编程世界的必修课-C语言

926020 学习 · 20793 问题

查看课程

相似问题