汽水瓶兑换汽水问题

1.汽水瓶

某商店规定:三个空汽水瓶可以换一瓶汽水,允许向老板借空汽水瓶(但是必须要归还)。
小张手上有n个空汽水瓶,她想知道自己最多可以喝到多少瓶汽水。
数据范围:输入的正整数满足 1≤n≤100

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

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 32M,其他语言64M

输入描述:

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

输出描述:

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

示例1

输入例子:3
 		  10
		  81
		  0
输出例子:1
		  5
		  40
		  
例子说明:
样例 1 解释:用三个空瓶换一瓶汽水,剩一个空瓶无法继续交换
样例 2 解释:用九个空瓶换三瓶汽水,剩四个空瓶再用三个空瓶换一瓶汽水,剩两个空瓶,向老板借一个空瓶再用三个空瓶换一瓶汽水喝完得一个空瓶还给老板

解题思路:用到递归的思想,当第一次兑换后,喝完的汽水瓶还能再次兑换,结束条件就是当手里还有两个汽水瓶时能再兑换一瓶汽水,还有一个或者没有汽水瓶时就不能再兑换了。

代码:

public static int SodaNum(int Bottle) {
		if(Bottle/3==0 && Bottle%3==2) {	//剩2个空瓶,还能喝一瓶
			return 1;
		}else if (Bottle/3==0 && Bottle%3!=2) {	//剩1个或者0个喝不了
			return 0;
		}
		else {
			return Bottle/3 + SodaNum(Bottle/3+Bottle%3);  //Bottle/3:本次兑换的汽水,Bottle%3:本次兑换剩余的汽水瓶
		}
	}
	
public static void main(String[] args) {
	Scanner scanner=new Scanner(System.in);
	while (true) {
		int BottleNum=scanner.nextInt();
		if (BottleNum==0) {		//结束条件
			break;
		}
//			System.out.println(BottleNum);
		int sum=0;
		sum=SodaNum(BottleNum);
		System.out.println(sum);
	}
	}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值