HDU1724,本体大意为给你一个椭圆的长半轴与短半轴a、b以及两条直线l与r让你求出夹杂在l与r之间的面积:本体思路很简单直接利用定积分牛顿--莱布尼茨公式求解定积分。纯粹一道数学题代码如下:
#include"stdio.h"
#include"math.h"
double absf(double a)
{
return a>0?a:-a;
}
#define PI 3.14159265
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int a,b,l,r;
scanf("%d%d%d%d",&a,&b,&l,&r);
double sita1 = -acos(1.0*l/a);
double sita2 = -acos(1.0*r/a);
double s1=absf(1.0/2*a*b*(PI-sita1))+1.0*a*b/4*(sin(2*sita1));
double s2=absf(1.0/2*a*b*(PI-sita2))+1.0*a*b/4*(sin(2*sita2));
printf("%.3lf\n",absf(2*(s2-s1)));
}
return 0;
}