题目描述
挂盐水的时候,如果滴起来有规律,先是滴一滴,停一下;然后滴二滴,停一 下;再滴三滴,停一下...,现在有一个问题:这瓶盐水一共有VUL毫升,每一滴是D毫升,每一滴的速度是一秒(假设最后一滴不到D毫升,则花费的时间也 算一秒),停一下的时间也是一秒这瓶水什么时候能挂完呢?
输入
输入数据占一行,由VUL和D组成,其中0< D< VUL< 5000。
输出
请输出挂完盐水需要的时间。
样例输入 Copy
10 1
样例输出 Copy
13
#include <stdio.h>
int main()
{
int n,m,i=1;
int sum=0,j;
scanf("%d%d",&m,&n);
while(m>0)
{ m-=i*n; /*用i表示滴下的滴数,每次减去滴下的数*/
if(m>=0) /*m<0就表示上次已经是最后一次滴下了*/
{
sum+=i;/*每次加上i,i为1就是1s*/
i++; /*i增加*/
}
if(m<0) /*小于0*/
{ j=m+i*n; /*将j变为最后一次滴之前毫升数*/
j=(j-1)/n+1;/*最后一滴是1s,那先加上,
这里(j-1)/n+1相当于向上取整,也就是说如果j不是n的整数倍,
那么就要多加一秒。例如,如果j是5,n是3,那么(j-1)/n+1等于2,而j/n等于1。
这样可以保证最后一次滴的时间不会少于实际的时间。*/
sum+=j;
}
if(m>0) /*m>0表示还在滴,间隔1s*/
sum++;
}
printf("%d",sum);
return 0;
}