递归测试 啤酒瓶问题

/*

 啤酒

 21

 4个瓶盖换1

 2个空瓶换1

 问:10元可以喝几瓶

 */



int lefttop,leftbottle;

int main(int argc, const char * argv[]) {

    

    int sum = 5;

    int count = drink(5, 5);

    printf("总共能喝%d\n剩下的瓶盖:%d\n剩下的空瓶:%d\n",count+sum,lefttop,leftbottle);

    

    return 0;

    

}

//implicit declaration of funtion is invalid in C99

int drink(int top,int bottle)

{

    if(bottle>=2 || top>=4)

    {

        leftbottle = bottle/2 + bottle%2 + top/4;

        lefttop = top/4 + top%4 + bottle/2;

        return (bottle/2)+(top/4)+drink(lefttop, leftbottle);

    }

    return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值