思路:
高中经典例题。分解加速度和速度就好了。
#include<bits/stdc++.h>
using namespace std;
const double g=9.8;
const int MAXN = 1000+5;
int main()
{
int i,j,k,n,m;
int _;
cin>>_;
double a,b,x,y;
while(_--)
{
cin>>a>>b>>x>>y;
double p=atan(b/a);
double h=y-(b/a)*fabs(x);//tanp=b/a,一直写成tan(b/a)真傻逼。
double vx=sqrt(2*h*g)*sin(p);
double vy=sqrt(2*h*g)*cos(p);
double l=fabs(x/cos(p));
// cout<<l<<endl;
double vxt=sqrt(vx*vx+2*g*sin(p)*l);
double tz=(vxt-vx)/(g*sin(p));
double t=vy/(g*cos(p));
// cout<<tz<<' '<<t<<endl;
double cc=tz/(2*t);
int ccc=cc;
ccc++;
cout<<ccc<<endl;
}
return 0;
}