(五猴分桃)海滩上有一堆桃子,五只猴子来分。第一只猴子把桃子平均分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二、三、四、五只猴子都是这样做的, 问海滩上原来最少有多少个桃子?

这个采用逆推法:

假设第五只猴子拿了x个桃子,

则第四只猴子拿了y=(x*5+1)/4,

第三只猴子拿了z=(y*5+1)/4个猴子......

以此类推到第一只猴子。

他要求一开始最少有多少个桃子,我们可以知道最后一只猴子拿走的最少,则一开始的桃子也是最少,则我们设count变量为最后一直猴子拿走的桃子数量。设flag为标志,如果找到了最少的则退出循环。

我们设total为float类型,因为for循环中有/4,如果设置为int类型/4则自动取整,我们可以根据for循环后将total转换为int类型与不转换为int类型的total相减是否为零来判断是否求出最少的桃子数量。

int main()
{
    float total,count=1;
    int i,flag=1;
    while(flag)
    {
        total=count;
        for(i=0;i<4;i++)
        {
            total=(total*5+1)/4;
        }
        total=total*5+1;
        if(total-(int)total==0)
        {
            flag=0;
            printf("最少为%0.f个",total);    
        }
        count=count+1;
    }
    return 0;
} 

最后结果为:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值