L3-013 非常弹的球 (物理)(30 分)

L3-013 非常弹的球 (30 分)

刚上高一的森森为了学好物理,买了一个“非常弹”的球。虽然说是非常弹的球,其实也就是一般的弹力球而已。森森玩了一会儿弹力球后突然想到,假如他在地上用力弹球,球最远能弹到多远去呢?他不太会,你能帮他解决吗?当然为了刚学习物理的森森,我们对环境做一些简化:

假设森森是一个质点,以森森为原点设立坐标轴,则森森位于(0, 0)点。
小球质量为w/100 千克(kg),重力加速度为9.8米/秒平方( m / s 2 m/s^2 m/s2)。
森森在地上用力弹球的过程可简化为球从(0, 0)点以某个森森选择的角度ang (0<ang<π/2) 向第一象限抛出,抛出时假设动能为1000 焦耳(J)。
小球在空中仅受重力作用,球纵坐标为0时可视作落地,落地时损失p%动能并反弹。
地面可视为刚体,忽略小球形状、空气阻力及摩擦阻力等。
森森为你准备的公式:

动能公式: E = m × v 2 / 2 E=m×v^2/2 E=m×v2/2
牛顿力学公式: F = m × a F=m×a F=m×a
重力: G = m × g G=m×g G=m×g
其中:

E - 动能,单位为“焦耳”
m - 质量,单位为“千克”
v - 速度,单位为“米/秒”
a - 加速度,单位为“米/秒平方”
g - 重力加速度

输入格式:

输入在一行中给出两个整数:1≤w≤1000 和 1≤p≤100,分别表示放大100倍的小球质量、以及损失动力的百分比p。

输出格式:

在一行输出最远的投掷距离,保留3位小数。

输入样例:

100 90

输出样例:

226.757

题解

最优角度为45°,中学物理好像有证明题,忘了,凭直觉试了试45°,就对了…
本来以为还要写个三分搜索来找最优解的…2233333…
初始速度 v = 2 × E / m v = \sqrt{2\times E / m} v=2×E/m 发 射 角 度 x = 45 ° 发射角度x = 45° x=45° d = 0 d=0 d=0.

  1. 计算垂直方向的 v y = v s i n ( x ) v_{y}=vsin(x) vy=vsin(x)
  2. 计算水平方向的 v x = v c o s ( x ) v_x=vcos(x) vx=vcos(x);
  3. 计算小球做一次抛物曲线运动的时间: t = 2 × v y / g t = 2\times v_y/g t=2×vy/g
  4. 更新移动的水平距离: d = d + v x t d = d + v_x t d=d+vxt
  5. 更新速度: v = v 1 − p v = v \sqrt{1-p} v=v1p
  6. 判断 v > 1e-10, 是则跳转1,否则结束算法,输出d.
代码
#include <bits/stdc++.h>
using namespace std;
const static double pi = 3.141592653;
const static double g = 9.8;
int main()
{
    double m, p;
    cin >> m >> p;
    m = m / 100;
    p = p / 100;
    double V = sqrt(2.0 * 1000.0 / m);
    double Vy = V * sin(pi/4);
    double Vx = V * cos(pi/4);
    double t = 2.0 * Vy / g;
    double d = 0.0;
    while(V > 1e-10)
    {
        d = d + Vx * t;
        V = V * sqrt(1.0-p);
        Vy = V * sin(pi/4);
        Vx = V * cos(pi/4);
        t = 2.0 * Vy / g;
    }
    printf("%.3f",d);
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值