求小球落地5次后所经历的路程和第5次反弹的高度

这篇博客探讨了一个小球从任意高度落下并每次反弹回原高度一半的物理问题。通过循环计算,确定了小球在第5次落地时共经历的总路程和第5次反弹的高度。程序使用C++编写,输入初始高度,输出结果精确到小数点后6位。示例中,当初始高度为1时,第5次落地经历的路程为2.875米,第5次反弹的高度为0.03125米。博客内容涉及数学建模和基础物理学知识。
摘要由CSDN通过智能技术生成

求小球落地5次后所经历的路程和第5次反弹的高度

描述
假设一个球从任意高度自由落下,每次落地后反跳回原高度的一半; 再落下, 求它在第5次落地时,共经历多少米?第5次反弹多高?

最后的误差判断是小数点6位

数据范围:输入的小球初始高度满足1<=n<=1000 ,且保证是一个整数

输入描述:
输入起始高度,int型

输出描述:
分别输出第5次落地时,共经过多少米第5次反弹多高

示例1
输入:
1
输出:
2.875
0.03125

#include<iostream>
//#include"stdio.h"
using namespace std;
//维护两个数组,分别表示第i次弹起高度dp和累计经历长度hp
//dp[0]=1;  设定初始高度
//dp[i]=dp[i-1]/2;
//hp[0]=1;  设定初始长度
//hp[i]=dp[i]*2+hp[i-1];
int main(){
    int n;
    cin>>n;
    //scanf("%d",&n);
    double dp[6]={1.0};
    double hp[6]={1.0};
    for(int i=1;i<6;++i){
        dp[i]=dp[i-1]/2.0;
    }
    for(int i=1;i<5;++i){
        hp[i]=hp[i-1]+2.0*dp[i];
    }
    double sum=hp[4]*n;
    double high=dp[5]*n;
    cout<<sum<<"\n"<<high<<endl;
    //printf("%.6f\n%.6f\n",sum,high);
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值