解题思路以及注意事项:

  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 条评论

给我五美元 5年前 回复TA
@或多或少 当N=1时,你看一下程序结果sum=1500,但是实际上sum为1000,注意是第几次落地之前走了多少米,不包括落地后反弹的
或多或少 5年前 回复TA
错误50% 怎么搞的  纠结



#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
    double M,N;
    double high,H;
    double sum=0;
    cin>>M>>N;
    for(int i=1;i<=N;i++ )
    {
        high=M*0.5;
        H=high+M;
        sum+=H;
        M=high;
    }
    cout<<high<<" "<<fixed<<setprecision(2)<<sum-high<<endl;
   return 0;
}
或多或少 5年前 回复TA
错误50% 怎么搞的  纠结



#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
    double M,N;
    double high,H;
    double sum=0;
    cin>>M>>N;
    for(int i=1;i<=N;i++ )
    {
        high=M*0.5;
        H=high+M;
        sum+=H;
        M=high;
    }
    cout<<high<<" "<<fixed<<setprecision(2)<<sum-high<<endl;
   return 0;
}
zzhajjl 5年前 回复TA
@手残 在某一次落到地面的总长度
手残 5年前 回复TA
sum+=2*iterm;                       //中间过程
         iterm=(double)iterm/2; 

中间过程是什么意思
XThRall 5年前 回复TA
谁能帮我看看我的问题在哪里?

#include <stdio.h>
#include <math.h>

int main()
{
	int M,N;
	double a,b,x,y,sumx=0.00,sumy=0.00;
	scanf("%d %d",&M,&N);
	
	
	for(int i=0;i<N;i++)
	{
		x=pow(0.5,i);
		y=pow(0.5,i+1);
		sumx+=x;
		sumy+=y;
		
	}
	printf("%.2f %.2f\n",sumx,sumy);
	a=M*y;
	b=M*(sumx+sumy);
	printf("%.2f %.2f",a,b);
	
	return 0;
}
王春晓 5年前 回复TA
#include<stdio.h>
#include<math.h>
int main()
{
  int M,N;
  double h,fenmu,SUM=0;
  scanf("%d%d",&M,&N);
  h=M/pow(2,N);
  printf("%.2f",h);
  for(fenmu=1;fenmu<=N;fenmu++)
  {
	SUM=SUM+(double)M/pow(2,fenmu-1)+(double)M/pow(2,fenmu);
  }
 printf(" %.2f\n",SUM);
  return 0;
}
我这为啥就1000 5不行,小一点的都行
王春晓 5年前 回复TA
@指头 #include<stdio.h> #include<math.h> int main() {   int M,N;   double h,fenmu,SUM=0;   scanf("%d%d",&M,&N);   h=M/pow(2,N);   printf("%.2f",h);   for(fenmu=1;fenmu<=N;fenmu++)   { 	SUM=SUM+(double)M/pow(2,fenmu-1)+(double)M/pow(2,fenmu);   }  printf(" %.2f\n",SUM);   return 0; }
指头 5年前 回复TA
#include <stdlib.h>
#include <stdio.h>
#include <string.h>

int main()
{
     double a=0,m,n,d,l,e=0;
     scanf("%lf\n",&n);//n次落地
     scanf("%lf\n",&m);//多少米高度
     if(n==1)
    {
          d=m;
     }else if(n>1)
    {
        l=n-1;
     while(l)
     {
          a=m/2;
          e=e+a;
          m=a;
          l--;
          
          
     }
     printf("第%d次%.2lf \n一共:%.2lf米\n",n,a,d+e);
    }
   
    return 0;
}
问题在哪?搞得迷糊了
jtr 5年前 回复TA
#include<stdio.h>
int main()
{double M,N,i;
 double sum=0;
scanf("%lf %lf",&M,&N);
if(N=1){sum=M;}
else{
    sum=M;
for(i=2;i<N+1;i++){
M=M/2;      哪里错了。。。
sum=sum+2*M;
    
}}

printf("%.2lf %.2lf",M,sum);
	return 0;
}