题目:两个相切的小圆r1,r2,同时外切于一个大圆R,已知两小圆的半径r1、r2,
或者过两小圆的被大圆截取的切线段长度t,求大圆面积减去两小圆面积为多少。
分析:计算几何。由题意可知如下等式:
R = r1 + r2;
t^2 = 4(R^2 - (r2-r1)^2)= 4r1r2;
整理,得:
S = π(R^2 - r1^2 - r2^2)= π 2r1r2 = π t^2 / 8。
说明:貌似没有不成立的数据啊(⊙_⊙)。
#include <iostream> #include <cstdlib> #include <cstdio> #include <cmath> using namespace std; double pi = 2.0*acos(0.0),a,b; char buf[101]; int main() { int n; while (cin >> n) { getchar(); while (n --) { gets(buf); if (sscanf(buf, "%lf%lf", &a,&b) == 1) { if (a >= 0) printf("%.4lf\n",pi*a*a*0.125); else printf("Impossible.\n"); }else { if (a >= 0 && b >= 0) printf("%.4lf\n",pi*a*b*2.0); else printf("Impossible.\n"); } } } return 0; }