题目:在一个圆形画圆中,在圆周上取3点构成三角形,然后再做三角形的内切圆,内切圆,三角形和内切圆间,
三角形和外接圆间;三个区域分别种上不同的花,问每种花的种植面积。
分析:计算几何、简单题。设三边为a、b、c;内切圆和外接圆半径分别r、R。
1.根据海伦定理求解三角形面积:S(ABC) = sqrt((a+b+c)*(a+b-c)*(a+c-b)*(b+c-a))/4;
2.同时,三角形面积S(ABC) = r*(a+b+c)/2;得:r = 2*S(ABC)/(a+b+c);
3.余弦定理,计算cosA = (b*b + c*c - a*a)/(2*b*c);
正弦定理,计算sinA = a/(2*R);得:R = a/(2*sinA);
求出两圆面积,做差即可。
#include <iostream> #include <cstdlib> #include <cstdio> #include <cmath> using namespace std; int main() { double p = acos(-1.0); double a,b,c,s,r,R,cosA; while ( ~scanf("%lf%lf%lf",&a,&b,&c) ) { //海伦定理,计算三角形面积 s = 0.25*sqrt((a+b+c)*(a+b-c)*(a+c-b)*(b+c-a)); //计算内切圆半径:r*(a+b+c) = s r = 2*s/(a+b+c); //余弦定理求角A cosA = (b*b+c*c-a*a)/(2*b*c); //正弦定理,求外接圆半径 a/(2*R) = sinA R = a/(2*sqrt(1-cosA*cosA)); printf("%.4lf %.4lf %.4lf\n",R*R*p-s,s-r*r*p,r*r*p); } return 0; }