为了账号安全,请及时绑定邮箱和手机立即绑定

递归函数还是很懵 求解答

猴子第一天摘下N个桃子,当时就吃了一半,还不过瘾,就又多吃了一个。第二天又将剩下的桃子吃掉一半,又多吃了一个。以后每天都吃前一天剩下的一半零一个。到第10天在想吃的时候就剩一个桃子了,问第一天共摘下来多少个桃子?并反向打印每天所剩桃子数。

在代码编辑器中:

第7,11,12行根据注释提示填写代码

运行结果为:

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



正在回答

2 回答

#include <stdio.h>

int getPeachNumber(n)

{

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

    if(n==10)

    {

       num=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;

}

哪里不懂再问我。

0 回复 有任何疑惑可以回复我~
#1

慕函数6368640

递归结束数条件num=1?不是return 1;吗?这个return 1;的1指的是剩余peach剩余量吗?还是天数?getpeachnumber(n+1)不太明白?
2019-08-03 回复 有任何疑惑可以回复我~
#2

小小疾飞 回复 慕函数6368640

num=1 return 1这两个有差吗? num就是剩下的桃子数量啊。你啥不明白?
2019-08-03 回复 有任何疑惑可以回复我~

就是高中高一教的递归函数,要有一个初始值(类如n=1时函数值为多少)和一个规律(比如f(x)=f(x-1)+2)


1 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
C语言入门
  • 参与学习       926018    人
  • 解答问题       20793    个

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

进入课程

递归函数还是很懵 求解答

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信