BZOJ 3199 escape
题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3199
题意:给出n个点。对于平面上任意一点p,p到n个点中的哪个点的距离最近我们就称p就被哪个点控制。有可能p被多个点同时控制(距离相等的时候)。给出一个矩形框(0,0,X,Y)以及框内一点q。从q到达矩形框上的途中,最少被多少个点控制过?
思路:n个点中的每个点有一个控制区域。某个点和其他点中垂线组成的半平面交就是这个区域。这个可以用凸包计算。这里是一个nlogn求凸包的算法,第二次遇到这个算法,第一次是:
http://www.cnblogs.com/jianglangcaijin/archive/2013/03/07/2947784.html
然后就是有公共边的连边求最短路。
point S,p[N];
struct Tline
{
point p1,p2;
int id;
double ang;
Tline(){}
Tline(point _p1,point _p2,int _id)
{
p1=_p1;
p2=_p2;
ang=atan2(p2.y-p1.y,p2.x-p1.x);
id=_id;
}
}L[N];
point crossPoint(Tline l1,Tline l2)
{
double ta=(l1.p2-l2.p1)*(l1.p1-l2.p1);
double tb=(l1.p1-l2.p2)*(l1.p2-l2.p2);
return (l2.p1*tb+l2.p2*ta)/(ta+tb);
}
double xx,yy;
int n,tot;
double dist(const point &a)
{
return sqrt(a.x*a.x+a.y*a.y);
}
int cmp(const Tline &a,const Tline &b)
{
if(sgn(a.ang-b.ang)==0) return sgn((a.p1-b.p1)*(b.p2-b.p1))<0;
return sgn(a.ang-b.ang)<0;
}
int onleft(const Tline &l1,const Tline &l2,const Tline &l3)
{
point tp=crossPoint(l1,l2);
return sgn((l3.p2-l3.p1)*(tp-l3.p1))>=0;
}
vector<int> g[N];
void hpi(int x)
{
sort(L+1,L+1+tot,cmp);
int i,tp=1;
for(i=2;i<=tot;i++) if(sgn(L[i].ang-L[i-1].ang)!=0) L[++tp]=L[i];
tot=tp;
int front=1,rear=1;
int Q[N];
Q[1]=1;
for(i=2;i<=tot;i++)
{
while(front<rear&&!onleft(L[Q[rear-1]],L[Q[rear]],L[i]))rear--;
while(front<rear&&!onleft(L[Q[front]],L[Q[front+1]],L[i]))front++;
Q[++rear]=i;
}
while(front<rear&&!onleft(L[Q[rear-1]],L[Q[rear]],L[Q[front]]))rear--;
while(front<rear&&!onleft(L[Q[front]],L[Q[front+1]],L[Q[rear]]))front++;
if(rear-front<2)return;
for(i=front;i<=rear;i++)
{
int y=L[Q[i]].id;
g[x].pb(y);
}
}
void work(int x)
{
tot=0;
L[++tot]=Tline(point(0,0), point(xx,0), n+1);
L[++tot]=Tline(point(xx,0), point(xx,yy),n+1);
L[++tot]=Tline(point(xx,yy),point(0,yy), n+1);
L[++tot]=Tline(point(0,yy), point(0,0), n+1);
int i;
for(i=1;i<=n;i++) if(i!=x)
{
point S=(p[i]+p[x])/2;
point d=(p[i]-p[x]).zhuanNi(PI/2);
point T=S+d;
L[++tot]=Tline(S,T,i);
}
hpi(x);
}
int bfs(int st)
{
queue<int> Q;
Q.push(st);
int i,dis[N],visit[N];
for(i=1;i<=n+1;i++) dis[i]=1e9,visit[i]=0;
dis[st]=0;
visit[st]=1;
while(!Q.empty())
{
int u=Q.front();
Q.pop();
for(i=0;i<SZ(g[u]);i++)
{
int v=g[u][i];
if(!visit[v])
{
visit[v]=1;
dis[v]=dis[u]+1;
Q.push(v);
}
}
}
return dis[n+1];
}
int main()
{
int T=getInt();
while(T--)
{
n=getInt();
xx=getInt(),yy=getInt();
S.get();
int i;
for(i=1;i<=n;i++)p[i].get(),g[i].clear();
for(i=1;i<=n;i++) work(i);
int st=1;
double tmp=dist(p[1]-S);
for(i=2;i<=n;i++) if(dist(p[i]-S)<tmp)
{
tmp=dist(p[i]-S);
st=i;
}
printf("%d\n",bfs(st));
}
return 0;
}
BZOJ 3199 escape的更多相关文章
- BZOJ 1340: [Baltic2007]Escape逃跑问题
1340: [Baltic2007]Escape逃跑问题 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 285 Solved: 133[Submit] ...
- POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流)
POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流) Description Yo ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 3940: [Usaco2015 Feb]Censoring
3940: [Usaco2015 Feb]Censoring Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 367 Solved: 173[Subm ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
- BZOJ 2879: [Noi2012]美食节
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
- bzoj 4610 Ceiling Functi
bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...
- BZOJ 题目整理
bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...
随机推荐
- -XX:+printGC
-XX:+printGC 可以打印GC的简要信息[GC 4790K->374K(15872K), 0.0001606 secs][GC 4790K->374K(15872K), 0.000 ...
- jQuery基础之让出$,与其他库共存
在某些情况下,可能有必要在同一个页面中使用多个JS库,由于很多库都使用$标识符(因为他简短方便),因此就需要一种方式来避免名称冲突. 为解决这个问题,jQuery提供了一个名叫.noConflict( ...
- 财务比率:ROE, 净利润增长率、毛利率、市盈率、PEG
净资产收益率是判断资产回报率指标,是最重要的财务数据 净利润增长率企业成长的参考指标 净利率企业获利能力的指标 毛利率企业获利能力的指标 资产负债率企业偿还债务的能力,也是重要的风险指标之其他还要根据 ...
- Qt可执行程序写入版本信息
[1]新建Qt工程 1.1 具体新建步骤不赘述. 1.2 新建工程后文件目录如下: 1.3 留意对比一下你的代码目录,可以发现我的文件目录中多了一个rc类型的资源文件.那么,它也就是关键点. 1.4 ...
- centos 7 systemctl
Linux Systemctl是一个系统管理守护进程.工具和库的集合,用于取代System V.service和chkconfig命令,初始进程主要负责控制systemd系统和服务管理器.通过Syst ...
- USB HID介绍【转】
本文转载自:http://blog.csdn.net/leo_wonty/article/details/6721214 HID是一种USB通信协议,无需安装驱动就能进行交互,在学习HID之前,先来复 ...
- 【python cookbook】【字符串与文本】15.给字符串中的变量名做插值处理
问题:想创建一个字符串,其中嵌入的变量名称会以变量的字符串值形式替换掉 解决方法:str.format().str.format_map() >>> s = '{name} has ...
- iOS 学习笔记 二 (2015.02.26)
How To Use Git Source Control with Xcode in iOS 6 If you're new here, you may want to subscribe to m ...
- 为博客启用MetaWeBlog API
最近想写一个博客系统,主要有以下几点功能. 能够使用Live Writer来发布.修改文章 使用MongoDB作为持久化 对于博客中的图片.CSS.JS文件,使用CDN加速 后期可加上Radis 使用 ...
- 【jqGrid for ASP.NET MVC Documentation】.学习笔记.3.本地化语言包
1 引用本地化语言包 在 js/i18n 文件夹中,提供了大量预定义的语言包.它包括为所有字符串定义的,包括消息,标题,分页信息,搜索/添加/删除 的对话框 文本等. 在jQuery库文件后,在jqG ...