解题思路以及注意事项:

  1. 用for()循环来模拟反弹的过程,注意不要忘了最后的反弹反弹高度以及开始落下的距离,其他的中间过程都是两倍的反弹高度。

  2. 注意不要弄错了scanf()里面的格式。

  3. 可以用double进行下强制转换。

实例代码:

#include"stdio.h"
int main()
{
    int size,i;
    double iterm=0,sum=0,high;                   //一定要初始化,不然后果不堪设想                             
    scanf("%lf %d",&high,&size);
    iterm=high;
    for(i=0;i<size;i++)                          //循环的开始和结束注意一下
    {
        if(i==0)                                 //加上最后的反弹
            sum+=iterm;                                
        else sum+=2*iterm;                       //中间过程
         iterm=(double)iterm/2;                  //强制转换,下次反弹前面的二分之一
    }
    printf("%0.2lf %0.2lf",iterm,sum);           //注意格式别错了
    return 0;
}

还有什么不懂的问题大家可以在下方的评论区提问,小方会为您解答

点赞(20)
 

0.0分

55 人评分

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

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

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

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

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

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

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

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

评论列表 共有 104 条评论

xiaohouge 5年前 回复TA
@xiaohouge 落地n次用公式求总长:总长=2*长-(4*长/2^n),公式求第n次落地时反弹高:高度=长/2^n
xiaohouge 5年前 回复TA
#include<stdio.h>
int main()
{
	int m,n,i;
	double m1=0,n1=2;
	scanf("%d%d",&m,&n);
	for(i=1;i<n;i++)
	{
		n1=n1*2;
		m1=m1+n1;
	}
	if(n==0)
	{
		printf("%d.00 %d.00\n",m,n);
	}
	else
	{
		printf("%.2lf %.2lf\n",m/n1,(m/n1*m1)+m);		
	}
	return 0;
}
柳成荫 5年前 回复TA
#include<stdio.h>
#include<stdlib.h>
int main()
{
    long double M,N,m,n;//m和n分别是反弹高度和历经路程
    scanf("%Lf %Lf",&M,&N);
    m=M*pow(0.5,N);
    n=M*(3-pow(0.5,N-2));
    printf("%.2Lf %.2Lf",m,n);
    return 0;
}
烈空坐mega 5年前 回复TA
你那个当size=1时为1000,size=2时为2000,那前面赋值给sum=1000为什么不加进去呢,想半天都想不出来。
Marlboro 6年前 回复TA
int i;
    double M,N,height;
    scanf("%lf %lf",&M,&N);
    double sum = M;
    height=M*pow(0.5,N);
    for(i=1;i<N;i++)
    {
        sum=sum+2*M*pow(0.5,i);
    }
    printf("%0.2lf %0.2lf",height,sum);
qianlan 6年前 回复TA
int main()
{
	float M,sum=0,a=0;
	int N;
	scanf("%f %d",&M,&N);
	for(int i=1;i<=N;i++)
	{
		sum+=M+a;
		a=M/2;
		M=M/2;
	}
	printf("%.2f %.2f\n",M,sum);
	return 0;
}
ThenSea 6年前 回复TA
@居夫人 @aolong 对头,网站的题目示例其实有点不严谨。。。。
科比你来 6年前 回复TA
兄弟你算一下第一次到第四次再说,你这叫捡了芝麻丢了西瓜,就算对了第五次的答案
cpython3 6年前 回复TA
答案显示对50%,有没有考虑到的情况!大佬们帮忙看看哪里忽略了。
#include <iostream>
#include <cstdio>
using namespace std;
double g_sum;
double Result(double M,double N)
{
	
	if(N!=0)
	{
		g_sum+=2*M;	  			 //每次的高度乘以2,但是多算了刚开始的一段,所以在main中最终结果要送去最开始的M 
		return Result(M/2,N-1);  //递归  每次距离 M 减半,次数 N 减 1	
	}
	else //N=0,即次数减为 0 的时候,当然不能再递归了 
	{
		return M;
	}
}
int main()
{
	double M,N;
	cin>>M>>N;
	cout<<Result(M,N)<<" ";	
	printf("%.2lf",g_sum-M);   //总距离要送去第一次多计算的距离 
	return 0;
}
李傲龍 6年前 回复TA
@居夫人 把最后输出的s变为s-M就可以了