2部分组成
//1.斜率为1的就是根号2乘以边长
//2.斜率不为1的就是sqrt(i*i+(i+1)*(i+1));(i为短的边)
//2条件边长为1的边同样适用!
//也可以用hypot,用法:s = hypot(x,y),s就为边长分别为x,y的斜边长!!!!!!!
#include<iostream>
#include<cstdio>#include<cmath>
using namespace std;
double f(int x,int y){
double t = sqrt(2);
double ans = 0;
for(int i = 1;i<x+y;++i)
ans += t*i;
ans += x*t;
for(int i = 0;i<x+y;++i)
ans += sqrt(i*i+(i+1)*(i+1));
return ans;
}
int main(void){
int n,a,b,c,d;
while(cin>>n){
for(int i = 1;i<=n;++i){
cin>>a>>b>>c>>d;
printf("%.3lf\n",fabs(f(a,b)-f(c,d))) ;
}
}
return 0;
}
链接: