自由落体
题目描述
在高为H的天花板上有n个小球,体积不计,位置分别为 0,1,2,…,n-1,在地面上有一个小车(长为L,高为K,距原点距离为S1)。已知小球下落距离计算公式为d=d=0.5×g×t^2,其中 g=10,t为下落时间。地面上的小车以速度V前进。
如下图:
小车与所有小球同时开始运动,当小球距小车的距离 ≤0.0001时,即认为小球被小车接受(小球落到地面后不能被接受)。
请你计算出小车能接受到多少个小球。
输入格式
键盘输入:
H,S1,V,L,K,n (l≤H,S1,V,L,K,n≤100000)
输出格式
屏幕输出:
小车能接受到的小球个数。
输入输出样例
输入
5.0 9.0 5.0 2.5 1.8 5
输出
1
说明/提示
当球落入车的尾部时,算作落入车内。
我的程序:
#include <iostream>
#include<math.h>
using namespace std;
int main()
{
double h,s1,v,l,k;
int n;
int ans;
ans=0;
cin>>h>>s1>>v>>l>>k>>n;
double t1=sqrt(h/5);
double t2=sqrt((h-k)/5);
double a1=s1+l-t2*v;//小球最高时车尾的位置
double a2=s1-t1*v;//小球最低时车头的位置
for(int i=0;i<n;i++)
{
if((a1-i)>=0.0001&&(a2-i)<=0.0001)
ans++;
}
cout<<ans<<endl;
return 0;
}
运行结果:
心得体会:
把题看明白还是非常重要的,就是因为理解错题意,导致方向变了,一开始以为距离小于0.0001是上下距离,后来才知道是左右距离。而且还要注意小车内部为空。