How many days?
8600的手机每天消费1元,每消费K元就可以获赠1元,一开始8600有M元,问最多可以用多少天?
Input
输入包括多个测试实例.每个测试实例包括2个整数M, k,(2 <= k <= M <= 1000).M = 0, k = 0代表输入结束.
Output
对于每个测试实例输出一个整数,表示M元可以用的天数。
Sample Input
2 24 30 0
Sample Output
35
这道题,确实有几个地方要注意一下。输入m=0,n=0时,代表输入结束。本来一直在while()括号中限定条件,可是,总是不对,会出现输入m=0或n=0时就结束了。所以我们可以换个思路,利用break语句,在while()循环里,限定条件。这道题刚看时,会遗漏他每k次奖励的钱,有可能会是k或k的倍数,让他可以再奖励。所以,for()循环中的m是要随着程序的经行而改变的,m++。当然,每k天就可以多一天了,i==k是不合适的,i会等于a*k,及i==a*k。这道题就可以解决了。
#include<iostream>
using namespace std;
int main()
{
int m,k;
while(cin>>m>>k)
{
if(m==0&&k==0)
break;
int i,a=1;
for(i=1;i<=m;i++)
{
if(i==a*k)
{
m++;
a++;
}
}
cout<<m<<endl;
}
return 0;
}