本文主要是介绍弹球距离,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
习题2.7 弹球距离 (15分)
设有一个球从高度为h米的地方落下,碰到地面后又弹到高度为原来p倍的位置,然后又落下,再弹起,再落下…。请编写函数求初始高度为h的球下落后到基本停下来(高度小于给定阈值TOL)时在空中所经过的路程总和。
函数接口定义:
double dist( double h, double p );
其中h
是球的初始高度,p
是球弹起高度与弹起前落下高度的比值;函数dist
要返回球下落后到基本停下来时在空中所经过的路程总和。注意:当弹起的高度小于裁判程序定义的常数TOL
时,弹起的距离不计算在内。
裁判测试程序样例:
#include <stdio.h>
#define TOL 1E-2double dist( double h, double p );int main()
{double h, p, d;scanf("%lf %lf", &h, &p);d = dist(h, p);printf("%.6f\n", d);return 0;
}/* 你的代码将被嵌在这里 */
输入样例:
1.0 0.4
输出样例:
2.319680
#include <stdio.h>
#define TOL 1E-2double dist( double h, double p );int main()
{double h, p, d;scanf("%lf %lf", &h, &p);d = dist(h, p);printf("%.6f\n", d);return 0;
}double dist( double h, double p ){double sum=h;h=h*p;do{sum+=2*h;h=h*p;}while(h>TOL);return sum;
}
这篇关于弹球距离的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!