地狱飞龙(自适应辛普森积分)

地狱飞龙
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 196 Accepted Submission(s): 60

Problem Description
最近clover迷上了皇室战争,他抽到了一种地狱飞龙,很开心。假设地域飞龙会对距离为d的敌人每秒造成k/d2伤害。假设地域飞龙位于坐标轴原点,以每秒v1的速度向y轴正方向移动,敌人在(x,0)的位置,以每秒v2的速度向x轴负方向移动。问,敌人至少有多少血量永远才不会被地狱飞龙喷死。(伤害是连续造成的,不是一秒一秒间断的)

Input
第一行为数据组数T(1<=T<=1000)
每组数据一行,包含4个实数,分别为v1,v2,x,k(1≤v1,v2,x,k≤10)。

Output
每组数据输出一行,为敌人最小血量,结果保留2为有效数字.

Sample Input

1
1 1 1 1

Sample Output

2.36

题意

分析

用自适应辛普森积分水过,当作模板了

trick

1.区间要开的大点,[0,40000+]可过,有些玄学?

代码

#include <bits/stdc++.h>
using namespace std;

#define ll long long
#define R(i,a,b) for(int i=a;i<b;++i)
#define mem(a,b) memset(a,b,sizeof(a))
//#pragma comment(linker, "/STACK:102400000,102400000")
//inline void read(int &x){x=0; char ch=getchar();while(ch<'0') ch=getchar();while(ch>='0'){x=x*10+ch-48; ch=getchar();}}
double v1,v2,x,k;
double F(double t)  
{  
    //Simpson公式用到的函数
    double ans=k/(((x-v2*t)*(x-v2*t))+(v1*t)*(v1*t));
    return ans;  
}  
double simpson(double a, double b)//三点Simpson法,这里要求F是一个全局函数  
{  
    double c = a + (b - a) / 2;  
    return (F(a) + 4 * F(c) + F(b))*(b - a) / 6;  
}  
double asr1(double a, double b, double eps, double A)//自适应Simpson公式(递归过程)。已知整个区间[a,b]上的三点Simpson值A  
{  
    double c = a + (b - a) / 2;  
    double L = simpson(a, c), R = simpson(c, b);  
    if (fabs(L + R - A) <= 15 * eps)return L + R + (L + R - A) / 15.0;  
    return asr1(a, c, eps / 2, L) + asr1(c, b, eps / 2, R);  
}  
double asr2(double a, double b, double eps)//自适应Simpson公式(主过程)  
{  
    return asr1(a, b, eps, simpson(a, b));  
} 

int main()
{
    int t;
    for(scanf("%d",&t);t--;)
    {
        scanf("%lf%lf%lf%lf",&v1,&v2,&x,&k);
        printf("%.2f\n",asr2(0,40000,1e-6));
    }
    return 0;
}
posted @ 2017-07-06 11:51  遗风忘语  阅读(269)  评论(0编辑  收藏  举报