乐羊羊饮料厂正在举办一次促销优惠活动。乐羊羊C型饮料,凭3个瓶盖可以再换一瓶C型饮料,并且可以一直循环下去,但不允许赊账。
请你计算一下,如果小明不浪费瓶盖,尽量地参加活动,那么,对于他初始买入的n瓶饮料,最后他一共能得到多少瓶饮料。
输入:一个整数n,表示开始购买的饮料数量(0<n<10000)
输出:一个整数,表示实际得到的饮料数例如:
用户输入:
100
程序应该输出:
149用户输入:
101
程序应该输出:
151
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
代码:
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()) {
int n = sc.nextInt();
//统计总共能 获得 多少 瓶 饮料
int count = n;
//记录能用 总共的瓶盖数 能兑换的 饮料数
int ret = n / 3;
//记录当前还剩的 瓶盖 数 (不够3个)
int tmp = n%3;
//循环遍历,当能兑换的饮料数为 0 时,结束循环
while(ret > 0) {
//将兑换后的饮料数量 累加到 count 中去
count += ret;
//手里剩余的瓶盖数 加上 新兑换饮料的瓶盖数
tmp += ret % 3;
//判断一下,如果手里剩余的瓶盖个数 大于等于3
if(tmp >= 3) {
//就能 又兑换 一瓶 新的饮料,将它 累加到ret 中,
ret += tmp/3;
//更新 tmp 手里剩余的瓶盖数
tmp %= 3;
}
//去商店用手里饮料的瓶盖兑换新的饮料
ret = ret / 3;
}
System.out.println(count);
}
}