原问题为:喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水,给20元,可以喝多少汽水?
首先我们可以思考一下用什么方法来解决?此处我想到的是循环
解题思路:首先我们可以创建变量
sum——可以喝的汽水总数
num——表示喝完当前所有汽水后的总空瓶数
t——表示兑换后的汽水数量
n——表示上一次兑换完后的空瓶数
由题目给出的条件应初始化sum=20,t=0,n=0,num=20.然后我们便可以开始找这几个变量之间的关系,由题易知t=num/2,sum+=t,num=t+n,n=num%2。
那么我们控制循环的条件是什么?
由于我们不确定循环的次数,故使用while/do···while循环更为合适(此处我使用的是do···while循环,大家可以自己尝试一下while循环)由题干可得只有2个空瓶才能兑换一瓶汽水,故只用当num>=2时循环才会继续,所以代码如下(此处我考虑了借汽水的情况,如果不考虑则答案为39)
根据此类问题,那我们是不是可以写出通用的代码?
由题可知,开始给的钱数,汽水的单价,以及空瓶子兑换汽水的数量要求都是可以变化的,我们不妨依次设为all , money ,number则仿照上面的代码,我们可以写出: