题解 | #汽水瓶#

汽水瓶

http://www.nowcoder.com/practice/fe298c55694f4ed39e256170ff2c205f

思路

  1. 样例解析有歧义,应该是借空瓶而不是借汽水
  2. 首先得到空瓶数量
  3. 分析后可知:3个空瓶才可以换1瓶汽水,因此换1瓶汽水,少3个空瓶;多1个汽水;多1个空瓶(因为换的汽水会喝完变为空瓶)
  4. 因为可以借空瓶,但是必须还,因此必须满足借多少还多少?如果自己有1个空瓶,借2个空瓶,换1个汽水的话,手里只有1个空瓶,如法满足借多少还多少的要求。
    因此,只有自己手里有2个空瓶,才能借1个空瓶,组成3个空瓶得到1瓶汽水,再将这瓶汽水喝完,还借的空瓶。

Answer

#include<stdio.h>

int main()
{
    //得到空瓶数量
    int n;
    while(scanf("%d",&n) != EOF){
        int able=0;
        if(n == 0){
            break;
        }
        while(n>1){
            
            if(n>=3){
                n -= 3;//少3个空瓶
                able++;//多1个汽水
                n++;//多1个空瓶
            }
            if(n ==2){//借1个空瓶
                able++;
                n=0;//还所有空瓶
            }
        }
        printf("%d\n",able);       
    }
    return 0;
    
}
全部评论
这才是正常人的思路!!
点赞 回复 分享
发布于 2022-07-07 00:36

相关推荐

10-21 23:48
蚌埠坦克学院
csgq:可能没hc了 昨天一面完秒挂
点赞 评论 收藏
分享
一名愚蠢的人类:多少games小鬼留下了羡慕的泪水
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
评论
10
2
分享
牛客网
牛客企业服务