acd the cover circle(分情况讨论)

Problem Description
用半径相等的两个圆覆盖一个w*h的矩形,要求两圆不相交且必须在矩形内。求覆盖面积最大时两圆半径。
Input

输入包含多组数据,EOF结束。

每组数据包含一行,分别是两个实数w和h代表矩形的长和宽。

0<w,h<10000

Output
每组数据输出一行表示圆的半径,小数点后保留三位。
Sample Input
2.000 1.000
Sample Output
0.500

(前提w>=h)当W>=2*h时,r=h/2; 当w<2*h时,两圆在巨型内斜着紧靠着,并两圆紧贴着边,根据计算可得 r*r-(w+h)*r+(w*w+h*h)/4=0 再解方程。

#include<stdio.h>
#include<math.h>
int main()
{
    double w,h,r,r1,b,c;
    while(scanf("%lf%lf",&w,&h)!=EOF)
    {
        if(w<h)
        {
            r=w; w=h; h=r;
        }
        if(w>=2*h)
            r=h/2;
        else
        {
            b=-(w+h); c=(w*w+h*h)/4.0;
            r=(-b+sqrt(b*b-4*c))/2;
            r1=(-b-sqrt(b*b-4*c))/2;
            if(r>h/2||r<r1&&r1<=h/2)r=r1;
        }
        printf("%.3lf\n",r);
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值