jkjkre 2019-03-08 17:49 采纳率: 100%
浏览 2387
已采纳

【c语言】:一个简单递归算法的调用:1020个西瓜几天后能卖完

算1020个西瓜几天后能卖完(第一天卖一半多两个,以后每天卖剩的一半多两个

#include <stdio.h>
int fun(int n,int t){


if(n>=0){fun(n-n/2-2,t++);}

return t;
}
main(){

int k=0,n=3000;
k=fun(n,k);

printf("%d",k);
}

运行结果一直为2,想不明白?
正确答案应该是8 ,错哪了呢?

  • 写回答

3条回答 默认 最新

  • 掉蛋 2019-03-10 17:09
    关注

    fun 变量的返回值没有保存下来

    #include <stdio.h>
    int fun(int n,int t)
    {
        int left = n - n/2 -2; 
        t ++; //执行一次这个函数,就算一天,left是执行完后剩余的西瓜。
        if(left > 0) { //如果>0 还要在卖一天
            t = fun(left, t);      
        }   
    
        return t;
    }
    int main(int argc, char **argv)
    {
        int k=0,n;
    
        n = atoi(argv[1]);
        k=fun(n,k);
    
        printf("%d\n",k);
    }
    
    

    使用形参不是很好理解,使用指针作为参数t就好理解了

    #include <stdio.h>
    void fun(int n,int *t)
    {
        int left = n - n/2 -2;
        *t = *t + 1;
        if(left > 0) {
           fun(left, t);
        }
    
        return ;
    }
    int main(int argc, char **argv)
    {
        int k=0,n;
    
        n = atoi(argv[1]);
        fun(n,&k);
    
        printf("%d\n",k);
    }
    
    
    
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 ffmpeg如何安装到虚拟环境
  • ¥188 寻找能做王者评分提取的
  • ¥15 matlab用simulink求解一个二阶微分方程,要求截图
  • ¥30 乘子法解约束最优化问题的matlab代码文件,最好有matlab代码文件
  • ¥15 写论文,需要数据支撑
  • ¥15 identifier of an instance of 类 was altered from xx to xx错误
  • ¥100 反编译微信小游戏求指导
  • ¥15 docker模式webrtc-streamer 无法播放公网rtsp
  • ¥15 学不会递归,理解不了汉诺塔参数变化
  • ¥15 基于图神经网络的COVID-19药物筛选研究