cf 744D
给你红点蓝点,找一个最大的圆,圆里没有蓝点并且至少有一个红点。边界可算可不算。
一开始没看懂题解,想了好久(一整天)才想明白是枚举弦上点二分半径check角度,看了下clj的代码发现思路都一样就开始写了。
借鉴了一下clj的代码。
调了一个多小时。
几个注意点:看到好多 random_shuffle 的,我没有,也感觉没什么必要。(另外cjl的代码去掉random_shuffle好像会WA。。。)
极角排序之后可能会遇到很多很多点全在一个角上,这个时候如果排序的话会麻烦,比方说我们要先减后加(哪里麻烦了啊???)
所以我每次check是不是扫完了完整的一段,也可以理解成我们扫角度不扫点。
小优化,每次二分先check ans,然后把l设成ans。
关于怎么求角的范围:两个圆夹起来就是了,初中解析几何?
千万不要把二分的eps设成1e-8,不然你会在test5tle到自闭并且还根本不知道哪里T了。
(感冒摸了三天鱼了。不过这题收获还蛮大的)
#include <bits/stdc++.h>
#define rep(x) for(int i=0;i<x;i++)
#define mk(a,b) make_pair(a,b)
using namespace std;
typedef double db;
const db eps=1e-;
const db pi=acos(-);
int sign(db k){
if (k>eps) return ; else if (k<-eps) return -; return ;
}
int cmp(db k1,db k2){return sign(k1-k2);}
struct point{
db x,y;
point operator + (const point &k1) const{return (point){k1.x+x,k1.y+y};}
point operator - (const point &k1) const{return (point){x-k1.x,y-k1.y};}
point operator * (db k1) const{return (point){x*k1,y*k1};}
point operator / (db k1) const{return (point){x/k1,y/k1};}
int operator == (const point &k1) const{return cmp(x,k1.x)==&&cmp(y,k1.y)==;}
// 逆时针旋转
point turn(db k1){return (point){x*cos(k1)-y*sin(k1),x*sin(k1)+y*cos(k1)};}
bool operator < (const point k1) const{
int a=cmp(x,k1.x);
if (a==-) return ; else if (a==) return ; else return cmp(y,k1.y)==-;
}
db abs(){return sqrt(x*x+y*y);}
db abs2(){return x*x+y*y;}
db dis(point k1){return ((*this)-k1).abs();}
db getw(){return atan2(y,x);}
int getP() const{return sign(y)==||(sign(y)==&&sign(x)==-);}
};
db cross(point k1,point k2){return k1.x*k2.y-k1.y*k2.x;}
db dot(point k1,point k2){return k1.x*k2.x+k1.y*k2.y;}
db slove(db S){
if(S<)S+=*pi;
else if(S>=*pi) S-=*pi;
return S;
}
point r[],b[];
vector<point> p;
int n,m;
vector<pair<db,int>> g;
bool check(int id,db R){
g.clear();
point o = p[id];
rep(n+m){
if(i==id)continue;
point tmp = p[i];
db d = tmp.dis(o);
if(cmp(d,R*)>=)continue;
db alf = acos(d//R);
db delta = atan2(tmp.y-o.y,tmp.x-o.x);
db l = slove(delta-alf),r=slove(delta+alf);
if(l<r){
g.push_back(mk(l,i<n?:));
g.push_back(mk(r,-(i<n?:)));
}else{
g.push_back(mk(l,i<n?:));
g.push_back(mk(*pi,-(i<n?:)));
g.push_back(mk(,i<n?:));
g.push_back(mk(r,-(i<n?:)));
}
}
if(id<n)g.push_back(mk(,id<n?:)),g.push_back(mk(*pi,-(id<n?:)));
sort(g.begin(),g.end());
int rn=,bn=;
rep(g.size()){
if((i==g.size()-||g[i].first!=g[i+].first)&&rn>&&bn<=)return true;
if(abs(g[i].second)==)
bn+=g[i].second;
else
rn+=g[i].second/;
}
return false;
}
//枚举弦上点,二分半径,check角度范围,判断是否可行
int main(){
//freopen("zibi.in","r",stdin);
scanf("%d%d",&n,&m);
rep(n) scanf("%lf%lf",&r[i].x,&r[i].y),p.push_back(r[i]);
rep(m) scanf("%lf%lf",&b[i].x,&b[i].y),p.push_back(b[i]);
bool f=;
rep(n+m)
if(check(i,1e15))
//return 0*printf("%d -1\n",i);
return *printf("-1\n");
db ans = ;
//random_shuffle(p.begin(),p.begin()+n);
//random_shuffle(p.begin()+n,p.end());
for(int i=;i<n+m;i++){
db l=ans,r=1e9;
if(check(i,ans)) {
while (l + eps < r) {
db mid = (l + r) / ;
if (check(i, mid))
l = mid;
else r = mid;
}
ans = l;
// printf("%d %.11f\n",i,ans);
}
}
printf("%.11f\n",ans);
}
/** */
/** */
cf 744D的更多相关文章
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
随机推荐
- Pytorch如何用预训练模型提取图像特征
方法很简单,你只需要将模型最后的全连接层改成Dropout即可. import torch from torchvision import models # load data x, y = get_ ...
- oracle insert into 插入多组数据方法总结
网上好多oracle 的文章,多是以oracle开头,内容确实其他sql,一幅气死人不偿命的嘴脸着实让人难受. 今天就更新点oracle 使用insert into插入数据的方式: 1.oracle ...
- Java编程思想(前十章)
Java编程思想 有C++编程基础的条件下, 前10章可以快速过一下,都是基本语法,不需要花太多时间. 着重中后段的一些章节,类型信息.泛型.容器.IO.并发等. 中文翻译版 阅读地址 对于一个架构师 ...
- Python——IPython和NumPy
IPython: 一个增强的Python shell:许多python对象的显示形式更友好.更详细的异常显示.增加额外的命令交互式数据处理 Tab键自动完成: 键入一些内容之后,按Tab键,显示可能的 ...
- String,下表和切片,分割
字符串介绍 1.字符串在内存中的存储 2.字符串的加法 3.字符串的格式化 1. 下标索引 所谓“下标”,就是编号,就好比超市中的存储柜的编号,通过这个编号就能找到相应的存储空间 字符串中" ...
- video作为背景全屏铺满问题
项目中我打算使用一个MP4视频作为登录界面背景,首先在静态页面都没法显示出来,后来发现需要将视频的编码格式转换为H264的格式方能正常显示(使用格式工厂转换即可): 后又发现视频没办法铺满全屏,在不同 ...
- 基于cxf的app文件上传接口(带回显功能)
1.SaleImpl @Override public String uploadPic(final List<Attachment> attachments) { return this ...
- 实例分析ASP.NET在MVC5中使用MiniProfiler监控MVC性能的方法
这篇文章主要为大家详细介绍了ASP.NET MVC5使用MiniProfiler监控MVC性能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 MiniProfiler ,一个简单而有效的迷你剖析器 ...
- c/c++再学习:C与Python相互调用
c/c++再学习:Python调用C函数 Python 调用C函数比较简单 这里两个例子,一个是直接调用参数,另一个是调用结构体 C代码 typedef struct { int i1; int i2 ...
- python第六天(元组、字典、集合)
一.元组(tuple) 作用:存多个值,对比列表来说,元组不可变(是可以当做字典的key的),主要用来读 定义:与列表类型相比,只不过把[ ]换成() age=(11,22,33,44,55)prin ...