牛客寒假五 b战队比赛地(三分)

在这里插入图片描述
对于这个问题,我们要找出离最远的训练基地最短距离的比赛地,我们可以用一个函数算出任意一个基地离最远训练基地的距离。然后我们不能直接遍历,需要在整个数轴范围内找到合适的位置,那么我们采取三分法,先定一个很小的左顶点和一个很大的右顶点,比较左顶点和右顶点的最大距离,每次排除三分之一的错误选项,可以按时求出答案,需要注意本题所有坐标都可以是小数,注意精度

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+100;
int n;
double x[N],y[N];
double f(double mid) 
{
    double mi = 0;
    for(int i = 1;i<=n;i++)
    {
        mi=max(mi,sqrt(y[i]*y[i]+(x[i]-mid)*(x[i]-mid)));
    } 
    return mi;
 } 
int main()
{
    scanf("%d",&n);
    for(int i = 1;i<=n;i++)
    {
        scanf("%lf%lf",&x[i],&y[i]);
    }
    double l=-1e4,r=1e4;
    for(int i=1;i<70;i++)
    {
        double mid1=l+(r-l)/3;
        double mid2=r-(r-l)/3;
        if(f(mid1) > f(mid2)) l=mid1;
        else r= mid2;
    }
    printf("%.10f",f(l));
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值