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.
- 计算垂直方向的 v y = v s i n ( x ) v_{y}=vsin(x) vy=vsin(x)
- 计算水平方向的 v x = v c o s ( x ) v_x=vcos(x) vx=vcos(x);
- 计算小球做一次抛物曲线运动的时间: t = 2 × v y / g t = 2\times v_y/g t=2×vy/g
- 更新移动的水平距离: d = d + v x t d = d + v_x t d=d+vxt
- 更新速度: v = v 1 − p v = v \sqrt{1-p} v=v1−p
- 判断 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;
}