题解 | #汽水瓶#

汽水瓶

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

#include <iostream>
using namespace std;

int BottleNum(int Allnum)
{
    int n1    = Allnum / 3; //置换空瓶得到的饮料数
    int n1_re = Allnum % 3; //剩下空瓶,不足以置换饮料

    int num = n1;
    int Emptynum = n1 + n1_re;
    while (Emptynum >= 2){ //新饮料瓶 + 剩下空瓶,是否可以通过借空瓶来换
                             //2是因为只有两空瓶时,可向老板借1个,喝完还回去,此时手里没瓶子了。
        Emptynum = n1 + n1_re;
        n1       = (Emptynum) / 3; 
        n1_re    = (Emptynum) % 3; 

        if (n1 == 0 && n1_re == 2){
            num += 1;
            break;
        }
        num += n1;
        
    }
 
   
    return num;
}

int main() {
    int input;
    while (cin >> input){
        if (input > 0){
            cout << BottleNum(input) <<endl;
        }
    }
    return 0;
}

全部评论

相关推荐

10-14 23:01
已编辑
中国地质大学(武汉) Java
CUG芝士圈:虽然是网上的项目,但最好还是包装一下,然后现在大部分公司都在忙校招,十月底、十一月初会好找一些。最后,boss才沟通100家,别焦虑,我去年暑假找第一段实习的时候沟通了500➕才有面试,校友加油
点赞 评论 收藏
分享
威猛的小饼干正在背八股:挂到根本不想整理
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务