题目:
Problem Description
挂盐水的时候,如果滴起来有规律,先是滴一滴,停一下;然后滴二滴,停一下;再滴三滴,停一下...,现在有一个问题:这瓶盐水一共有VUL毫升,每一滴是D毫升,每一滴的速度是一秒(假设最后一滴不到D毫升,则花费的时间也算一秒),停一下的时间也是一秒这瓶水什么时候能挂完呢?
Input
输入数据包含多个测试实例,每个实例占一行,由VUL和D组成,其中 0<D<VUL<5000。
Output
对于每组测试数据,请输出挂完盐水需要的时间,每个实例的输出占一行。
Sample Input
10 1
Sample Output
13
个人理解:
10 1
13
不要用等比数列求和的方法倒过来求停的次数,当剩余的体积不够下次滴的时候,退出循环,记录循环次数,还有滴的时间可以用总VUL除以X,得到的结果如果有小数,那么加1秒
代码<C语言>
#include<stdio.h>
#include<math.h>
int main()
{
int time;
double x,y,i,count;
while(scanf("%lf%lf",&y,&x)!=EOF)//输入数据(现学的)
{
//printf("y %lf x %lf \n",y,x);
count=0; //这个变量为已经滴下的液体体积
for(i=1;i<5000;i++)
{
count=count+i*x;
//printf("count的值为:%lf\n",count);
//printf("y-cont的值为:%lf\n",(y-count));
//printf("if前面的i值:%d\n",i);
if(i*x+x>(y-count)) //判断剩余的液体体积是否足够下一次滴的量
break;
}
if(y-count==0)
i=i--;
//printf("最后抛出的i的值为:%d\n",(int)i);
//printf("y/x的值为:%lf\n",y/x);
//printf(" int y/x的值为:%d\n",(int)(y/x));
if((y/x)>(int)(y/x)) //如果VUL除以x的值带有小数,那么去小数另外加一
time=(int)(y/x)+1;
else
time=y/x;
//printf("小时间为:%d\n",time);
printf("%d\n",time+(int)i);
}
return 0;
}
#include<math.h>
int main()
{
int time;
double x,y,i,count;
while(scanf("%lf%lf",&y,&x)!=EOF)//输入数据(现学的)
{
//printf("y %lf x %lf \n",y,x);
count=0; //这个变量为已经滴下的液体体积
for(i=1;i<5000;i++)
{
count=count+i*x;
//printf("count的值为:%lf\n",count);
//printf("y-cont的值为:%lf\n",(y-count));
//printf("if前面的i值:%d\n",i);
if(i*x+x>(y-count)) //判断剩余的液体体积是否足够下一次滴的量
break;
}
if(y-count==0)
i=i--;
//printf("最后抛出的i的值为:%d\n",(int)i);
//printf("y/x的值为:%lf\n",y/x);
//printf(" int y/x的值为:%d\n",(int)(y/x));
if((y/x)>(int)(y/x)) //如果VUL除以x的值带有小数,那么去小数另外加一
time=(int)(y/x)+1;
else
time=y/x;
//printf("小时间为:%d\n",time);
printf("%d\n",time+(int)i);
}
return 0;
}