UVa 10991 - Region

题目:求三个互切圆所围面积。

分析:简单题、计算几何。海伦定理+余弦定理。

#include <stdio.h>
#include <stdlib.h>
#include <string.h> 
#include <math.h>

double pi = acos(-1.0);

int main()
{
	int    n;
	double r1,r2,r3,a,b,c,p,s;
	while ( scanf("%d",&n) != EOF )
	while ( n -- ) {
		scanf("%lf%lf%lf",&r1,&r2,&r3);
		a = r1+r2;
		b = r1+r3;
		c = r2+r3;
		p = (a+b+c)*0.5;
		s = sqrt(p*(p-a)*(p-b)*(p-c));
		double a1 = acos((a*a+b*b-c*c)/2.0/a/b);
		double a2 = acos((b*b+c*c-a*a)/2.0/c/b);
		double a3 = acos((a*a+c*c-b*b)/2.0/a/c);
		double ss = 0.5*(a1*r1*r1+a2*r3*r3+a3*r2*r2);
		printf("%.6lf\n",s-ss);
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值