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


    地狱飞龙
    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
    ",asr2(0,40000,1e-6));
        }
        return 0;
    }
    
  • 相关阅读:
    Row Cache lock Problem
    AIX操作系统上安装Oracle数据库必不可少的几项检查工作
    如何使用MOS风格的代码背景?
    在Ubuntu 10上使用DLink DWA 130无线网卡
    PL/SQL Developer View SQL功能的一个Bug
    11g新特性SQL PLUS 错误日志
    生病了。。。
    ORA00600: [7005], [192]内部错误一例
    Linux:vmware下ubuntu更换网卡后无法识别网卡
    Linux:LFS:第一天:今天开始学习,计划7天时间
  • 原文地址:https://www.cnblogs.com/chendl111/p/7125540.html
Copyright © 2020-2023  润新知