17-汽水瓶

利用空瓶换汽水的算法实现

题目

某商店规定:三个空汽水瓶可以换一瓶汽水,允许向老板借空汽水瓶(但是必须要归还)。

小张手上有n个空汽水瓶,她想知道自己最多可以喝到多少瓶汽水。

数据范围:输入的正整数满足 1≤n≤100

注意:本题存在多组输入。输入的 0 表示输入结束,并不用输出结果。

输入描述:

输入文件最多包含 10 组测试数据,每个数据占一行,仅包含一个正整数 n( 1<=n<=100 ),表示小张手上的空汽水瓶数。n=0 表示输入结束,你的程序不应当处理这一行。

输出描述:

对于每组测试数据,输出一行,表示最多可以喝的汽水瓶数。如果一瓶也喝不到,输出0。

示例1

输入:

3

10

81

0

输出:

1

5

40

说明:

样例 1 解释:用三个空瓶换一瓶汽水,剩一个空瓶无法继续交换

样例 2 解释:用九个空瓶换三瓶汽水,剩四个空瓶再用三个空瓶换一瓶汽水,剩两个空瓶,向老板借一个空瓶再用三个空瓶换一瓶汽水喝完得一个空瓶还给老板


思路1

剩2个空瓶子时,可以先找老板借一瓶汽水,喝掉这瓶满的,喝完以后用3个空瓶子换一瓶满的还给老板。

也就是说2个空瓶子即可换一瓶汽水喝,而且喝完之后手里也没有空瓶子。

每次空瓶的数量除以2,直到最后空瓶的数量少于两瓶,就累加到了可兑换的数量。


代码1

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNextInt()) {
            int bottle = sc.nextInt();
            if (bottle == 0) {
                break;
            }
            System.out.println(bottle / 2);
        }
    }
}

代码2

import java.util.*;

public class Main {
    public static int getNum(int num) {
        //累加汽水的个数
        int sum = 0;
        //while(num > 0) 死循环
        while (num > 1) {
            //兑换的汽水的个数 /3
            sum += num / 3;
            //剩余的空瓶子 /3 + %3
            num = num / 3 + num % 3;
            if (num == 2) {
                //借一瓶
                ++sum;
                break;
            }
        }
        return sum;
    }
    
    public static void main(String[] args) {
        Scanner s = new Scanner(System.in);
        int num;
        while ((num = s.nextInt()) != 0) {
            System.out.println(getNum(num));
        }
    }
}

汽水 时间限制: 1.0 Sec 内存限制: 128 MB 提交: 0 解决: 51 [提交] [状态] [讨论版] [命题人: 18958865698] 难度 题目描述 欧阳对汽水有着近乎痴迷的喜爱,仿佛永远无法满足他对汽水的渴望。然而,令人感到不悦的是,他常常囊中羞涩,因此他唯一合法获取汽水的方式就是通过收集并回收汽水瓶来换取资金,从而购买新的汽水瓶以继续他的汽水之旅。他不仅会回收自己过的瓶,有时还会在街头巷尾拾起被遗弃的瓶。在某个特别渴望解渴的日子里,他决定要不停地畅饮汽水,直至他的经济状况不再允许他购买新的汽水为止。 输入 输入共一行,包含三个非负整数 e,f,c ,其中 e≤10^​8,代表欧阳在一天开始时拥有的汽水瓶子的数量,f≤10^​8等于在一天中发现的汽水瓶子的数量,2≤c≤2×10^​8等于购买一杯新汽水所需的瓶子的数量。 输出 输出一个整数,代表欧阳在这特别口渴的一天了多少汽水。 样例输入1 复制 9 0 3 样例输出1 复制 4 样例输入2 复制 5 5 2 样例输出2 复制 9 提示 样例一解释 开始时欧阳共有 9+0=9 个汽水瓶子,每 3汽水瓶子可以兑换 1瓶汽水,兑换了 3 瓶汽水,还剩 0 个汽水瓶子。3 瓶汽水完,又有了 3汽水瓶子,有可以兑换 1 瓶汽水,完后只剩 1 个汽水瓶,无法再兑换了。共了 4 瓶汽水。
05-11
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值