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

zoj 1608 Two Circles and a Rectangle 判断两个圆是否能放入一个矩形中

时间:2014-05-08 14:17:58      阅读:377      评论:0      收藏:0      [点我收藏+]

标签:style   blog   class   code   java   color   

题目来源:
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=608

分析:

两个圆放到矩形的临界点图为:

bubuko.com,布布扣

其中a为长, b为宽, r1 > r2

红色三角形的三边长分别为:

x = a - (r1 +r2)

y = b - (r1 + r2)

z = r1 +r2

当 x ^ 2 + y ^ 2  >= z^2 时, 显然 矩形是可以放进去圆的。

代码如下:

bubuko.com,布布扣
int main()
{
    double w, l , r1 ,r2 ;
   while( scanf("%lf%lf%lf%lf" , &w, &l ,&r1 ,&r2)!= EOF){
        if(w > l)
            swap(w, l) ;
        if(r1 > r2)
            swap(r1 , r2) ;
        double r = r1 +r2 ;
        double d = (l -r)*(l -r) + (w -r)*(w -r) ;
        if( (w  > 2*r2 ) && (d > r*r) )
            puts("Yes");
        else puts("No") ;
   }

}
bubuko.com,布布扣

 

zoj 1608 Two Circles and a Rectangle 判断两个圆是否能放入一个矩形中,布布扣,bubuko.com

zoj 1608 Two Circles and a Rectangle 判断两个圆是否能放入一个矩形中

标签:style   blog   class   code   java   color   

原文地址:http://www.cnblogs.com/zn505119020/p/3713727.html

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