原题链接:[编程入门]自由下落的距离计算
解题思路:
次数 | 落地后的路程S | 反弹点H |
1 | S(1)=M | H(1)=M/2 |
2 | S(2)=M+M/2+M/2=S(1)+2*H(1) | H(2)=(M/2)/2=M/22=H(1)/2 |
3 | S(3)=S(2)+2*H(2) | H(3)=H(2)/2 |
4 | S(4)=S(3)+2*H(3) | H(4)=H(3)/2 |
…… | …… | …… |
注意事项:
参考代码:
#include <stdio.h>
int main()
{
float m,n,s=0,h; //s经过的路程,h反弹高度
int i;
scanf("%f%f",&m,&n);
//第1次
s=m;
h=m/2;
//第2次之后
for(i=2;i<=n;i++)
{
s+=2*h;
h=h/2;
}
printf("%.2f\t%.2f",h,s);
return 0;
}
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复