NOIP学习之循环控制:13.球弹跳高度的计算

测试链接
总时间限制: 1000ms 内存限制: 65536kB
描述
一球从某一高度落下(整数,单位米),每次落地后反跳回原来高度的一半,再落下。
编程计算气球在第10次落地时,共经过多少米? 第10次反弹多高?

输入
输入一个整数h,表示球的初始高度。
输出
输出包含两行:
第1行:到球第10次落地时,一共经过的米数。
第2行:第10次弹跳的高度。

注意:结果可能是实数,结果用double类型保存。
提示:输出时不需要对精度特殊控制,用cout << ANSWER,或者printf("%g", ANSWER)即可。
样例输入
20
样例输出
59.9219
0.0195313

#include<iostream>

using namespace std;
int main()
{	int n,m=10;
	double sum,high;
	scanf("%d",&n);
	
	high=n;  //初始高度就是20
	sum=n;    
	while(m>=2)
	{
		sum+=high;  //加上来回的高度正好等于上一次球弹起的高度
		high/=2.0;	
		--m;
	}
	
	high/=2.0;//虽然到了10次,要计算弹起的高度
	printf("%g\n%g\n",sum,high);
	return 0;
}

发布了22 篇原创文章 · 获赞 0 · 访问量 153

猜你喜欢

转载自blog.csdn.net/wlxiong/article/details/104278457