题目
题目链接:1072: 汽水瓶
题解&思路
这一题我采用的是递归,但是怎么去想呢?
我们肯定需要一个辅助函数来计算多少瓶:
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
LinkedList<Integer> res=new LinkedList<>();
int x;
while ((x=scanner.nextInt())!=0) {
//辅助函数计算的值保存到集合中,初始值fullBott为0;
res.add(sumDrinks(x,0));
}
for (int i = 0; i < res.size(); i++) {
//对集合进行遍历输出得到最终结果
System.out.println(res.get(i));
}
}
接下来我们就来思考辅助函数中的内容:
/*辅助函数,里面的nullBott 代表的是空瓶的数量,而fullBott代表的是已经换了多少瓶满饮料的数量*/
int sumDrinks(int nullBott,int fullBott) {
//base case
// 当空瓶的数量小于2的时候,这时候就是再去借一瓶也不能兑换,所以返回
if(nullBott<2) {
return fullBott;
}
//接下来考虑可以借一瓶的情况
int borrow=0;
if(nullBott==2) {
borrow+=1;
}
//然后就是怎么去递归,首先考虑nullBott:我们要计算还有多少空瓶,
//最终空瓶的数量=当前空瓶的数量+兑换的汽水数量(喝完)+借的一瓶喝完的数量
//当前空瓶的数量=兑换完汽水还剩下的空瓶((nullBott+borrow)%3)
//兑换的汽水数量(喝完)=兑换的汽水的数量 (nullBott/3)
//然后就考虑fullBott里面的内容:
//总共兑换了多少汽水=之前兑换的数量+这次用空瓶兑换的汽水数量+借的一瓶=fullBott+(nullBott/3)+borrow
return sumDrinks((((nullBott+borrow)%3)+((nullBott/3)+borrow)),fullBott+(nullBott/3)+borrow);
}
思路清晰,女少不可言!