解题思路以及注意事项:
用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分
71 人评分
#include<iostream> using namespace std; int main() { float M,N; float sum=0; cin>>M>>N; sum=M; for(int i=0;i<N-1;i++) { M=M/2; sum+=M*2; } M=M/2; printf("%.2f\n",M); printf("%.2f\n",sum); //system("pause"); return 0; } 我的最简洁明了
错误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; }
错误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; }
sum+=2*iterm; //中间过程 iterm=(double)iterm/2; 中间过程是什么意思
zzhajjl 2019-07-18 10:03:14 |
在某一次落到地面的总长度
谁能帮我看看我的问题在哪里? #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; }
#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不行,小一点的都行
#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; } 问题在哪?搞得迷糊了
王春晓 2019-07-05 22:19:40 |
#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; }
#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; }
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:567 |
【偶数求和】 (C语言代码)浏览:637 |
C语言程序设计教程(第三版)课后习题6.3 (C++代码)浏览:944 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:633 |
【计算球体积】 (C语言代码)浏览:1101 |
C语言考试练习题_保留字母 (C语言代码)浏览:699 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:531 |
1011题解浏览:760 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:581 |
出圈】指针malloc版浏览:355 |