题目背景
温馨提醒:吸烟有害健康,请勿尝试吸烟!
题目描述
Peter 有 �n 根烟,他每吸完一根烟就把烟蒂保存起来,�k(�>1k>1)个烟蒂可以换一个新的烟,那么 Peter 最终能吸到多少根烟呢?
与某些脑筋急转弯不同的是,Peter 并不能从异次元借到烟蒂,抽完后再还回去。
输入格式
每组测试数据一行包括两个整数 �,�n,k(1<�,�≤1081<n,k≤108)。
输出格式
对于每组测试数据,输出一行包括一个整数表示最终烟的根数。
输入输出样例
输入 #1
4 3
输出 #1
5
输入 #2
10 3
输出 #2
14
说明/提示
对于 100%100% 的数据,1<�,�≤1081<n,k≤108。
代码+思路
#include<bits/stdc++.h>
int i,j,k,m,n,s;//定义变量。其中i、j为循环变量(j没有使用),n、k为输入用变量,s作为累加器使用,m为吸一次烟所产生的烟蒂。同时,n也作为烟蒂总累加器。
int main()
{
scanf("%d%d",&n,&k);//输入两个量
s+=n;//先累加一次吸过的烟
while(n>=k){//当n比k大时进入循环,循环效果:产生并累加烟
m=n%k;//获得m个烟蒂
n/=k;//获得n个烟
s+=n;//累加烟
n+=m;//累加烟蒂
}
printf("%d",s);//输出
return 0;
}