码迷,mamicode.com
首页 > 其他好文 > 详细

UVa 10573 - Geometry Paradox

时间:2014-10-29 12:57:55      阅读:751      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   os   ar   sp   数据   div   2014   

题目:两个相切的小圆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;
}


            S = π(R^2 - r1^2 - r2^2);

UVa 10573 - Geometry Paradox

标签:style   blog   io   os   ar   sp   数据   div   2014   

原文地址:http://blog.csdn.net/mobius_strip/article/details/40583949

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!