题解 | #汽水瓶#

汽水瓶

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

def max_sodas(empty_bottles):
    total_sodas = 0
    while empty_bottles >= 3:
        # 计算本轮汽水数量增加
        sodas = empty_bottles // 3
        total_sodas += sodas
        # 更新最新的空水瓶:上一轮剩余的空瓶+刚刚喝完的空瓶
        empty_bottles = empty_bottles % 3 + sodas
    
    # 如果有两个剩余的空,再借一个空的
    if empty_bottles == 2:
        total_sodas += 1
    
    return total_sodas

# 读取input中每一个element,到0停止
while True:
    empty_bottle = int(input().strip())
    if empty_bottle == 0:
        break
    print(max_sodas(empty_bottle))

看到有的解答是直接n//2的,有没有大佬讲下为啥这样可以啊。还是默认是借一个瓶子?

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-04 18:25
点赞 评论 收藏
分享
05-09 12:23
已编辑
华南理工大学 Java
野猪不是猪🐗:给他装的,双九+有实习的能看的上这种厂我直接吃⑨✌们拿它练练面试愣是给他整出幻觉了
点赞 评论 收藏
分享
06-11 17:39
门头沟学院 Java
小呆呆的大鼻涕:卧槽,用户彻底怒了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务