CodeForces - 1059D——二分/三分
题目
简单的说,就是作一个圆包含所有的点且与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——二分/三分的更多相关文章
- CodeForces - 1059D(二分+误差)
链接:CodeForces - 1059D 题意:给出笛卡尔坐标系上 n 个点,求与 x 轴相切且覆盖了所有给出点的圆的最小半径. 题解:二分半径即可.判断:假设当前二分到的半径是 R ,因为要和 x ...
- Codeforces 939E Maximize ( 三分 || 二分 )
题意 : 给出两个操作,① 往一个序列集合(初始为空)里面不降序地添加数字.② 找出当前序列集合的一个子集使得 (子集的最大元素) - (子集的平均数) 最大并且输出这个最大差值 分析 : 首先关注 ...
- 第二次组队赛 二分&三分全场
网址:CSUST 7月30日(二分和三分) 这次的比赛是二分&三分专题,说实话以前都没有接触过二分,就在比赛前听渊神略讲了下.......不过做着做着就对二分熟悉了,果然做题是学习的好方法啊~ ...
- Codeforces Gym100543B 计算几何 凸包 线段树 二分/三分 卡常
原文链接https://www.cnblogs.com/zhouzhendong/p/CF-Gym100543B.html 题目传送门 - CF-Gym100543B 题意 给定一个折线图,对于每一条 ...
- HDU 2298 Toxophily 【二分+三分】
一个人站在(0,0)处射箭,箭的速度为v,问是否能够射到(x,y)处,并求最小角度. 首先需要判断在满足X=x的情况下最大高度hmax是否能够达到y,根据物理公式可得 h=vy*t-0.5*g*t*t ...
- CF 8D Two Friends 【二分+三分】
三个地点构成一个三角形. 判断一下两个人能否一起到shop然后回家,如果不能: 两个人一定在三角形内部某一点分开,假设沿着直线走,可以将问题简化. 三分从电影院出来时候的角度,在对应的直线上二分出一个 ...
- CodeForces - 363D --二分和贪心
题目:CodeForces - 363D 题意:给定n个学生,其中每个学生都有各自的私己钱,并且自己的私己钱只能用在自己买自行车,不能给别人. 给定m个自行车,每个自行车都有一个价格. 给定公有财产a ...
- 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 ...
- Toxophily-数论以及二分三分
G - Toxophily Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submi ...
随机推荐
- [USACO 2016Dec] Team Building
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=4742 [算法] 动态规划 用Fi,j,k表示约翰的前i头牛和保罗的前j头牛匹配 , ...
- 【JSOI 2009】 Count
[题目链接] 点击打开链接 [算法] 二维树状数组 [代码] #include<bits/stdc++.h> using namespace std; #define MAXN 300 # ...
- NOIP2007普及 守望者的逃离
传送门 普及组的题目……很水. 原来写了一个模拟不过好像状态考虑的不全得了80,这次我们考虑一下dp做法. 守卫者有两种移动的方法,一种是闪现,一种是跑,我们可以把闪现和跑分开处理. 首先只处理闪现的 ...
- Spring AOP schema找不到报错 原
转自:https://my.oschina.net/zetaplusae/blog/144821 使用jersey+spring构建RESTful服务,并将应用部署在不能连接外网的服务器上.部署时,报 ...
- centos7安装redis3.2.12
1.准备安装包,放在/usr/local/src/ 2.解压安装包,解压到/usr/local/ tar zxf redis-3.2.12.tar.gz -C /usr/local/ 3.cd /us ...
- 51 nod 1521 一维战舰(二分)
传送门 题意 分析 这是我在51nod上的第2题,下载了4个数据,得不偿失?我太菜啦 一开始wa了6个点,下数据后发现舰与舰不能相邻,再交wa,发现l和r都没设好,再wa,发现check里面[1,b[ ...
- Codeforces Round #355 (Div. 2) B. Vanya and Food Processor
菜菜菜!!!这么撒比的模拟题,听厂长在一边比比比了半天,自己想一想,然后纯模拟一下,中间过程检测一下,妥妥的就可以过. 题意:有N个东西要去搞碎,每个东西有一个高度,然后有一台机器支持里面可以达到的最 ...
- (12)用css设计电子相册 {下}
本篇学习资料讲解: 延续上一篇的学习资料,仍然介绍 使用css对电子相册进行排版 和 侧面强调“盒子模型.标准流.浮动和定位”的重要性. 上篇学习资料介绍的“阵列模式电子相册”,如果也能 ...
- POJ 2104 K-th Number && 洛谷 P3834 【模板】可持久化线段树 1(主席树)
我惊奇的发现这两道题一模一样 题目背景 这是个非常经典的主席树入门题——静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个整数构成的序列,将对于指定的闭区间查询 ...
- PMD - Avoid autogenerated methods to access private fields and methods of inner / outer classes
PMD错误 Avoid autogenerated methods to access private fields and methods of inner / outer classes 样例 p ...