你拿着n元去买汽水,汽水一元一瓶,两个空瓶子可以换一个汽水,问一共可以喝多少瓶
int n = 0;
scanf_s("%d", &n);
int total = 0;
int empty = 0;
total = n;
empty = n;
while (empty / 2)
{
total += empty / 2;
empty= empty/2 + empty%2;
}
这是常见的一种情况,先把n元全部买入汽水,然后用空瓶去换汽水,换完后又变成空瓶,不过需要注意的是,有时候会剩下一个空瓶,那么下次换的时候就要加上上次剩下的
empty= empty/2 + empty%2
empty/2为每次能换的
empty%2为每次剩下的
if (n == 0)
{
total = 0;
}
else
{
total = 2 * n - 1;
}
还有一种较为简单的代码
一瓶1元,两个空瓶可换一瓶,说明每瓶的价值应该为0.5
所以n元应该可以喝2*n瓶,但是需要注意的是最后会剩下一瓶,所以应该是2*n-1
20元可以喝39瓶,最后会剩下一个空瓶子
如果你可以去向老板借一个瓶子,然后那这两个瓶子去换一瓶,喝完后把这瓶还回去。即可喝到40瓶(有待考究)