原题链接:[编程入门]自由下落的距离计算
解题思路以及注意事项:
用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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
if(i==0) //加上最后的反弹 sum+=iterm; else sum+=2*iterm; //中间过程 iterm=(double)iterm/2; 这俩个有疑问,就是不应该是iterm=(double)iterm/2先执行,然后再执行sum+=2*iterm,反弹后减半,然后就是先除以2,接下来就是下落和上升两个过程用 sum+=2*iterm;找出公式,其实就是等比求和 第N次落地时反弹an=m/2^n 共经过sn=3*m-4*an 代码如下: #include"stdio.h" void main() { double i,n,m,An=1.0,Sn=1.0; scanf("%lf%lf",&m,&n); for(i=0;i<n;i++) An/=2; An=m*An; Sn=3*m-4*An; printf("%.2lf %.2lf\n",An,Sn); }@yu19891222 #include<stdio.h> int main() { double m,n,c=0; scanf("%lf%lf",&m,&n); while(n>0){ c+=m; m=0.5*m; c+=m; n--; } c-=m; printf("%.2lf %.2lf",m,c) ; return 0; } 这是不是更简单??#include<stdio.h> #include<math.h> int main() { int i=1; int m,n; double a,b,c=0; scanf("%lf %d",&m,&n); a= m/pow(2,n); while(i<=n) { b=m+m/2; m=m/2; c=c+b; i++; } printf("%.2f %.2f\n",a,c); return 0; }我这个程哪里有问题,请帮忙指出#include<stdio.h> #include<math.h> int main() { int i=1; int m,n; double a,b,c=0; scanf("%lf %d",&m,&n); a= m/pow(2,n); while(i<=n) { b=m+m/2; m=m/2; c=c+b; i++; } printf("%.2f %.2f\n",a,c); return 0; }我这个程序哪里错了#include<stdio.h> int _tmain(int argc, _TCHAR* argv[]) { int b,i; double x=0,a; scanf("%Lf %d",&a,&b); for(i=1;i<=b;i++) { if(i<=2) { x+=1000; a=a/2; } else { x+=2*a; a=a/2; } } printf("%0.2Lf %0.2Lf",a,x); return 0; } 感觉没毛病啊!!!