Google kickstart 2013 Practice Round Captain Hammer 题解
生活随笔
收集整理的這篇文章主要介紹了
Google kickstart 2013 Practice Round Captain Hammer 题解
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Captain Hammer 題解
題目鏈接
題意
飛機以θ角度起飛,速度為V(固定值),給出終點的距離D和速度V,計算起飛的角度θ。
題解
這道題涉及到了物理上的平拋運動(高中物理和大學物理都有涉及到)。
可以將飛機的飛行過程看作是兩部分:先是逆向平拋(地面到最高點)和平拋(最高點到地面)。
推導過程
tanα=vyvx=g?tvx(1)tanα=\frac{v_y}{v_x}=\frac{g*t}{v_x}(1)tanα=vx?vy??=vx?g?t?(1)
t=D2vx(2)t=\frac{\frac{D}{2}}{v_x}(2)t=vx?2D??(2)
vx=V?cosα(3)v_x=V*cosα(3)vx?=V?cosα(3)
得出
sin(2α)=g?DV2sin(2α)=\frac{g*D}{V^2}sin(2α)=V2g?D?
α=arcsin(g?DV2)2α=\frac{arcsin(\frac{g*D}{V^2})}{2}α=2arcsin(V2g?D?)?
注意點
題目要求精度在10-6內,可以使用eps進行精度處理。
代碼
#include<cstdio> #include<cmath>using namespace std;#define PI acos(-1) #define Equ(a,b) ((fabs((a) - (b)))<(eps))const double eps = 1e-6;double solve(int v,int d){double s = (9.8*d)/pow((double)v,2);if(Equ(s,1.000000)) s = 1.000000;//防止對asin函數越界,進行精度校正return asin(s)*180/(PI*2); }int main() {int t=0;scanf("%d",&t);for(int i=0;i<t;++i){int d,v=0;scanf("%d%d",&v,&d);printf("Case #%d: %.7lf\n",i+1,solve(v,d));} }總結
以上是生活随笔為你收集整理的Google kickstart 2013 Practice Round Captain Hammer 题解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Linux]history命令用法详解
- 下一篇: Could not establish