题解 | #汽水瓶#
汽水瓶
http://www.nowcoder.com/practice/fe298c55694f4ed39e256170ff2c205f
思路
- 样例解析有歧义,应该是借空瓶而不是借汽水
- 首先得到空瓶数量
- 分析后可知:3个空瓶才可以换1瓶汽水,因此换1瓶汽水,少3个空瓶;多1个汽水;多1个空瓶(因为换的汽水会喝完变为空瓶)
- 因为可以借空瓶,但是必须还,因此必须满足借多少还多少?如果自己有1个空瓶,借2个空瓶,换1个汽水的话,手里只有1个空瓶,如法满足借多少还多少的要求。
因此,只有自己手里有2个空瓶,才能借1个空瓶,组成3个空瓶得到1瓶汽水,再将这瓶汽水喝完,还借的空瓶。
Answer
#include<stdio.h>
int main()
{
//得到空瓶数量
int n;
while(scanf("%d",&n) != EOF){
int able=0;
if(n == 0){
break;
}
while(n>1){
if(n>=3){
n -= 3;//少3个空瓶
able++;//多1个汽水
n++;//多1个空瓶
}
if(n ==2){//借1个空瓶
able++;
n=0;//还所有空瓶
}
}
printf("%d\n",able);
}
return 0;
}