题目
设有一个球从高度为h米的地方落下,碰到地面后又弹到高度为原来p倍的位置,然后又落下,再弹起,再落下…。请编写函数求初始高度为h的球下落后到基本停下来(高度小于给定阈值TOL)时在空中所经过的路程总和。
代码
#include <stdio.h>
#include <stdlib.h>
#define TOL 1E-3
double dist( double h, double p );
int main()
{
double h, p, d;
scanf("%lf %lf", &h, &p);
d = dist(h, p);
printf("%.6f\n", d);
system("pause");
return 0;
}
double dist( double h, double p ){
double k,count=0.0;
k=h;
while(k*p >= TOL){
count+=k*p*2;
k=k*p;
}
count+=h;
return count;
}
总结
一开始用了递归,可是递归的结果跟最后给出的答案总是有差。