具体题目如下:
乐羊羊饮料厂正在举办一次促销优惠活动。乐羊羊C型饮料,凭3个瓶盖可以再换一瓶C型饮料,并且可以一直循环下去,但不允许赊账。
请你计算一下,如果小明不浪费瓶盖,尽量地参加活动,那么,对于他初始买入的n瓶饮料,最后他一共能得到多少瓶饮料。
解题思路:
我们可以单纯地从逻辑角度切入,假想一开始买100瓶饮料,思考后续的兑换过程
总结一下兑换过程就是:
不断循环计算 ,每次(除了第一次)都会有新换到的瓶盖数+上一次换饮料剩下的瓶盖数, 用这个量再对3求商、取余,直到瓶盖数不够3个即可。
C语言源码如下:
#include<stdio.h>
int main()
{
int n,s,y,k;//s代表每次换饮料的商,y代表余数,k代表总共可换的饮料数,
//n代表一开始买的瓶数也代表每次循环启动时手里的瓶盖数
scanf("%d",&n);
k = n;
for(;n >= 3;)//如果剩下不到3个瓶盖,就寄了 这里用While更好
{
s = n / 3;
y = n % 3;
k = k + s;
n = s + y;
}
printf("%d",k);
return 0;
}