题目

题目链接

简单的说,就是作一个圆包含所有的点且与x轴相切,求圆的最小半径

方法一

分析:求最小,对半径而言肯定满足单调性,很容易想到二分。我们二分半径,然后由于固定了与X轴相切,我们对于每一个点,就可以算出这个点在圆上的时候圆与x轴相交的距离(其实就是圆心的x轴的范围)。然后对每个点都可以求一个圆心的横坐标区间,如果所有的区间有相交区域,则该半径满足条件,否则不满足。

代码:

 #include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std; const int maxn = + ;
const double esp = 1e-;
struct Piont
{
double x, y;
}p[maxn];
int n; bool judge(double r)
{
double ml = -1e15, mr = 1e15;
for (int i = ; i < n; i++)
{
if (p[i].y > * r) return false; //大于2倍半径的,肯定不行
double tmp = sqrt( * p[i].y * r - p[i].y * p[i].y);
if (p[i].x - tmp > ml) ml = p[i].x - tmp;
if (p[i].x + tmp < mr) mr = p[i].x + tmp;
}
return ml <= mr; //所有区间必须要有交点
} int main()
{
while (scanf("%d", &n) == )
{
int flag1 = , flag2 = ;
for (int i = ; i < n; i++)
{
scanf("%lf%lf", &p[i].x, &p[i].y);
if (p[i].y > ) flag1 = ;
if (p[i].y < ) flag2 = ;
if (p[i].y < ) p[i].y = -p[i].y;
}
if (flag1 && flag2)
{
printf("-1\n");
continue;
} double l = , r = 1e15, mid; //直接枚举圆的半径,范围大约是1e7的平方
int cnt = ; //二分100次精度足够了
while (cnt--) //这里写成(r - l) < esp陷入了死循环。。。
{
mid = (r + l) / 2.0;
if (judge(mid)) r = mid;
else l = mid;
}
printf("%.10lf\n", r);
}
return ;
}

方法二

分析:设圆心的横坐标为x,由勾股定理有(x-x0)2 + (r-y)2 = r2,得r = (x-x0)2/2y + y/2,所以R = max(r1,r2,,,rn),也就是说x确定时,R也随之确定。

我们又发现,对于答案所在得X,在它左右走R都会单调递增,形成像山谷那样得形状,那么直接三分X直接找到谷底即可。

具体的三分做法如下:

设答案所在区间为(l,r),dx = (r-l)/3,则mr = r+dx,ml = l-dx。设cal(x)是计算圆心在x时r的值,若cal(ml) < cal(mr),有两种情况,异侧如①,同侧如③,所以将r更新为mr,而不是更新为ml,同理,若cal(ml) > cal(mr),则将l更新为ml。

代码:

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; const int maxn = + ;
const double esp = 1e-;
struct Piont
{
double x, y;
}p[maxn];
int n; double cal(double x)
{
double r = ;
for (int i = ; i < n; i++)
r = max(r, p[i].y / 2.0 + (x - p[i].x) * (x - p[i].x) / p[i].y / 2.0);
return r;
} int main()
{
while (scanf("%d",&n) == )
{
int flag1 = , flag2 = ;
for (int i = ; i < n; i++)
{
scanf("%lf%lf", &p[i].x, &p[i].y);
if (p[i].y > ) flag1 = ;
if (p[i].y < ) flag2 = ;
if (p[i].y < ) p[i].y = -p[i].y;
}
if (flag1 && flag2)
{
printf("-1\n");
continue;
}
//R=y1/2 + (x-x1)^2/2y,x是圆心坐标,R关于x先减后增
double l = -1e7, r = 1e7,dx; //枚举圆的半径,也就是枚举圆心横坐标
while (r - l > esp) //也可改成cnt<100
{
dx = (r - l) / 3.0;
double lx = l + dx, rx = r - dx;
if (cal(lx) - cal(rx) < ) r = rx;
else l = lx;
}
int tmp = cal(r);
printf("%.6lf\n", cal(r));
}
return ;
}

参考链接:

https://blog.csdn.net/lzc504603913/article/details/82949923

https://blog.csdn.net/qq_37555704/article/details/82949337

http://www.cnblogs.com/sdfzhsz/p/9748360.html

https://blog.csdn.net/winter2121/article/details/82949159?tdsourcetag=s_pctim_aiomsg

CodeForces - 1059D——二分/三分的更多相关文章

  1. CodeForces - 1059D(二分+误差)

    链接:CodeForces - 1059D 题意:给出笛卡尔坐标系上 n 个点,求与 x 轴相切且覆盖了所有给出点的圆的最小半径. 题解:二分半径即可.判断:假设当前二分到的半径是 R ,因为要和 x ...

  2. Codeforces 939E Maximize ( 三分 || 二分 )

    题意 : 给出两个操作,① 往一个序列集合(初始为空)里面不降序地添加数字.② 找出当前序列集合的一个子集使得 (子集的最大元素) - (子集的平均数) 最大并且输出这个最大差值 分析 :  首先关注 ...

  3. 第二次组队赛 二分&三分全场

    网址:CSUST 7月30日(二分和三分) 这次的比赛是二分&三分专题,说实话以前都没有接触过二分,就在比赛前听渊神略讲了下.......不过做着做着就对二分熟悉了,果然做题是学习的好方法啊~ ...

  4. Codeforces Gym100543B 计算几何 凸包 线段树 二分/三分 卡常

    原文链接https://www.cnblogs.com/zhouzhendong/p/CF-Gym100543B.html 题目传送门 - CF-Gym100543B 题意 给定一个折线图,对于每一条 ...

  5. HDU 2298 Toxophily 【二分+三分】

    一个人站在(0,0)处射箭,箭的速度为v,问是否能够射到(x,y)处,并求最小角度. 首先需要判断在满足X=x的情况下最大高度hmax是否能够达到y,根据物理公式可得 h=vy*t-0.5*g*t*t ...

  6. CF 8D Two Friends 【二分+三分】

    三个地点构成一个三角形. 判断一下两个人能否一起到shop然后回家,如果不能: 两个人一定在三角形内部某一点分开,假设沿着直线走,可以将问题简化. 三分从电影院出来时候的角度,在对应的直线上二分出一个 ...

  7. CodeForces - 363D --二分和贪心

    题目:CodeForces - 363D 题意:给定n个学生,其中每个学生都有各自的私己钱,并且自己的私己钱只能用在自己买自行车,不能给别人. 给定m个自行车,每个自行车都有一个价格. 给定公有财产a ...

  8. Codeforces Round #425 (Div. 2) Problem C Strange Radiation (Codeforces 832C) - 二分答案 - 数论

    n people are standing on a coordinate axis in points with positive integer coordinates strictly less ...

  9. Toxophily-数论以及二分三分

    G - Toxophily Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submi ...

随机推荐

  1. 【NOI 2015】软件包管理器

    [题目链接] 点击打开链接 [算法] 树链剖分,子树的DFS序也是连续的一段 要注意细节! [代码] #include<bits/stdc++.h> using namespace std ...

  2. 【POJ 2406】 Power Strings

    [题目链接] 点击打开链接 [算法] KMP 如果字符串中存在循环节,则next[len] = (循环节个数 - 1) * 循环节长度 循环节个数 = len / (len - next[len]) ...

  3. 量子纠缠2——CHSH不等式

    问题 有Alice和Bob两个人,随机给他们两个数x和y(0或1),然后A和B根据他们得到数(x和y)给两个个数a和b(0或1). 规则如下: 如果输入的x和y都是1,那么,Alice和Bob给出不一 ...

  4. sublime text 3中修改tab键为缩进4个空格

    1. 菜单栏里点击 Preferences-> Setting-User, 如图 2. 在弹出来的文本里,添加如下两行: { // 注意只有一个大括号,如果之前有属性,如在之前的属性后确保有 , ...

  5. E20180408-hm

    interaction  n. 互动; 一起活动; 合作; 互相影响; interface n. 界面; <计>接口; 交界面;   v. (使通过界面或接口) 接合,连接; [计算机] ...

  6. 51nod 1267【二分】

    思路: 首先我们能够很容易地想到,4个数的和,拆成两两相加:a+b=-c-d; 我们也能很轻松地求出两两之和,但是呢..不同的和会存在相同的值相加,所以还要排除这个条件.具体操作就是标记一下,然后将和 ...

  7. hdoj1028;他们说这题叫dp...

    #include<cstdio> #include<string> #include<iostream> #include<vector> #inclu ...

  8. 7天学完Java基础之7/7

    Object类的toString方法 类Object是类层次结构的根类 每个都使用Object作为超类 所有对象都实现这个类的方法 //这个是Object类的子类,实现了其所有方法 public cl ...

  9. SpringBoot的配置文件加载顺序以及如何获取jar包里的资源路径

    一.读取配置文件的四种方式 这四种配置文件放置方式的读取优先级依次递减,具体可以查看官方文档. 1.1jar包同级目录下的config文件夹里的配置文件 其实我以前就见过这种方式了,只是不知道怎么做的 ...

  10. android 浏览器对图片加载高度渲染问题

    今天在开发有道汉语词典移动版的时候遇到了一个很奇怪的问题. 在android设备上访问的时候,总是发现有底部背景色不能完全渲染出来的情况(有时候又是正常的,一会儿出现一会儿不出现,iphone设备也是 ...