解题思路:首先需要理解整个过程,可以在大脑中想象,也可以通过用笔计算或者实践操作来理解。首先利用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.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论