解题思路:首先需要理解整个过程,可以在大脑中想象,也可以通过用笔计算或者实践操作来理解。首先利用for循环表示N次的反弹,因为每次反弹只能到原来高度的二分之一,所以每次将原高度除以2,因为反弹后的的高度和再次下落的高度一样,所以需要两次计算,又因为最后一次落地后不在计算反弹高度,所以再循环外再减去一个反弹高度h即可。
注意事项:一定要自习看题,多思考过程,再运用书学知识求解。
参考代码:
#include<stdio.h>
#include<math.h>
int main()
{
float M,s,h;
int N,i;
s=0;
scanf("%f %d",&M,&N);//接受M,N的值
h=M; //将M的值赋值给h,h表示高度
for(i=1;i<=N;i++)//利用for循环表示N次落地
{
s+=h; //现将开始下落的高度保存到路程中
h=h/2; //每次反弹高度为原高度的一半
s+=h; //把要反弹的高度加到路程里边
}
s-=h; //因为第N次落地后不在求反弹高度,所以将上述for循环中第三条语句加入的h再减去
printf("%.2f %.2f",h,s); //最后打印输出结果
return 0;
}
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复