java 饮料换购

饮料换购

乐羊羊饮料厂正在举办一次促销优惠活动。乐羊羊C型饮料,凭3个瓶盖可以再换一瓶C型饮料,并且可以一直循环下去,但不允许赊账。

请你计算一下,如果小明不浪费瓶盖,尽量地参加活动,那么,对于他初始买入的n瓶饮料,最后他一共能得到多少瓶饮料。

输入:一个整数n,表示开始购买的饮料数量(0<n<10000)
输出:一个整数,表示实际得到的饮料数

例如:
用户输入:
100
程序应该输出:
149

用户输入:
101
程序应该输出:
151

资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

每次的瓶盖数都是换的+不够数换饮料的瓶盖

import java.util.Scanner;

public class Main {
	static int num = 0;    //总的瓶数
	public static void main(String args[]){
		Scanner sc = new Scanner(System.in);
		num = sc.nextInt();  //将一开始买的瓶数加进去总数
		account(num);
		System.out.println(num);
	}
	public static void account(int n) {
		if(n>=3) {
			num+=n/3;     //每次换的瓶数加上去
			n=n/3+n%3;			//得出瓶盖数
			account(n);			//递归
		}
		else return;
	}
}

原文地址:https://www.cnblogs.com/ohuo/p/12232513.html