原题链接:[编程入门]自由下落的距离计算
解题思路以及注意事项:
用for()循环来模拟反弹的过程,注意不要忘了最后的反弹反弹高度以及开始落下的距离,其他的中间过程都是两倍的反弹高度。
注意不要弄错了scanf()里面的格式。
可以用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;
}还有什么不懂的问题大家可以在下方的评论区提问,小方会为您解答
0.0分
55 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
#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; }#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; }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);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; }答案显示对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; }