饮料换购问题:
乐羊羊饮料厂正在举办一次促销优惠活动。乐羊羊C型饮料,凭3个瓶盖可以再换一瓶C型饮料,并且可以一直循环下去,但不允许赊账。 请你计算一下,如果小明不浪费瓶盖,尽量地参加活动,那么,对于他初始买入的n瓶饮料,最后他一共能得到多少瓶饮料。 输入:一个整数n,表示开始购买的饮料数量(0<n<10000) 输出:一个整数,表示实际得到的饮料数 例如: 用户输入: 100 程序应该输出: 149 用户输入: 101 程序应该输出: 151
解答: 开始有n瓶饮料,因为换购回来的饮料数量足够的话,还可以继续换购,所以可以用一个循环解决问题。 n/3:用n瓶饮料第一轮能够直接换到的饮料。 n%3:完整第一轮换购后剩下的饮料。 n/3+n%3:n瓶饮料总共能换回的饮料数量。 所以可以一直循环至n的值小于3,,n<3时,停止循环,n已经无法再换购饮料。
public class result{
public static void main(String args
[]){
Scanner input
= new Scanner(System
.in
);
int n
= input
.nextInt();
int sum
= n
;
while(n
>=3){
sum
+= n
/3;
n
=(n
/3 + n
% 3);
}
System
.out
.println(sum
);
}
}