bzoj4080
分组赛时wy大神讲的题,网上都是随机化的题解
我来讲一下正解吧,我们穷举两个点,这两点距离要小于限制
然后我们分别以这两个点为圆心,两点距离为半径画圆
圆圆相交的部分被两点练成线段划分成两部分,不难发现
每个部分内点点之间的距离是小于限制的,很明显想到二分图
对于上半部分与下半部分的两点,如果距离大于限制则连边
然后我们求最大点独立集即可
求最大独立集的方案各种想错,实在太SB
做完最大匹配后首先先把未匹配的点拉出来,然后把他们有边相连的点都标记
然后处理每对匹配,若一个点被标记则选另一个点
这样是不可能出现两个点都标记的匹配,因为这样就会出现一条增广路,与最大匹配矛盾
type node=record
po,next:longint;
end; var e,ee:array[..] of node;
q,q1,q2,c,x,y,cy,cx,p:array[..] of longint;
v,v1,v2:array[..] of boolean;
z,ll,d,t1,t2,i,j,k,l,ans,len,n:longint; procedure add(x,y:longint);
begin
inc(len);
e[len].po:=y;
e[len].next:=p[x];
p[x]:=len;
ee[len].po:=x;
ee[len].next:=q[y];
q[y]:=len;
end; function dfs(x:longint):longint;
var i,y:longint;
begin
i:=p[x];
while i<> do
begin
y:=e[i].po;
if not v[y] then
begin
v[y]:=true;
if (cy[y]=-) or (dfs(cy[y])=) then
begin
cy[y]:=x;
cx[x]:=y;
exit();
end;
end;
i:=e[i].next;
end;
exit();
end; function match:longint;
var i:longint;
begin
fillchar(cy,sizeof(cy),);
fillchar(cx,sizeof(cx),);
match:=t1+t2;
if (t2=) or (t1=) then exit;
for i:= to t1 do
if cx[i]=- then
begin
fillchar(v,sizeof(v),false);
match:=match-dfs(i);
end;
end; function cross(i,j,k:longint):longint;
begin
exit((x[i]-x[k])*(y[j]-y[k])-(x[j]-x[k])*(y[i]-y[k]));
end; function dis(i,j:longint):longint;
begin
exit(sqr(x[i]-x[j])+sqr(y[i]-y[j]));
end; begin
readln(n,d);
d:=d*d;
for i:= to n do
readln(x[i],y[i]);
ans:=;
c[]:=;
for i:= to n- do
for j:=i+ to n do
if dis(i,j)<=d then
begin
ll:=dis(i,j);
t1:=;
t2:=;
fillchar(p,sizeof(p),);
fillchar(q,sizeof(q),);
len:=;
for k:= to n do
if (dis(i,k)<=ll) and (dis(j,k)<=ll) then
begin
if cross(k,j,i)>= then
begin
inc(t1);
q1[t1]:=k;
end
else begin
inc(t2);
q2[t2]:=k;
end;
end;
for k:= to t1 do
for l:= to t2 do
if dis(q1[k],q2[l])>d then add(k,l); l:=match;
if l>ans then
begin
ans:=;
fillchar(v1,sizeof(v1),false);
fillchar(v2,sizeof(v2),false);
for k:= to t1 do
if cx[k]=- then
begin
inc(ans);
c[ans]:=q1[k];
z:=p[k];
while z<> do
begin
v2[e[z].po]:=true;
z:=e[z].next;
end;
end; for k:= to t2 do
if cy[k]=- then
begin
inc(ans);
c[ans]:=q2[k];
z:=q[k];
while z<> do
begin
v1[ee[z].po]:=true;
z:=ee[z].next;
end;
end; for k:= to t1 do
if cx[k]<>- then
begin
inc(ans);
if not v1[k] then c[ans]:=q1[k]
else c[ans]:=q2[cx[k]];
end;
end;
end;
writeln(ans);
for i:= to ans do
write(c[i],' ');
writeln;
end.
bzoj4080的更多相关文章
- 【随机化】bzoj4080 [Wf2014]Sensor Network
#include<cstdio> #include<algorithm> #include<cmath> using namespace std; typedef ...
- 【BZOJ4080】【WF2014】Sensor Network [随机化]
Sensor Network Time Limit: 2 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description 魔法炮来到了帝都 ...
- 【bzoj4080】[Wf2014]Sensor Network 随机化
题目描述 魔法炮来到了帝都,除了吃特色菜之外,还准备去尝一尝著名的北京烤鸭.帝都一共有n(1<=1<=100)个烤鸭店,可以看成是二维平面内的点.不过由于魔法炮在吃烤鸭之前没有带钱,所以吃 ...
随机推荐
- app进入后台申请10分钟活跃时间-b
IOS允许长时间在后台运行的情况有7种: audio VoIP GPS 下载新闻 和其它附属硬件进行通讯时 使用蓝牙进行通讯时 使用蓝牙共享数据时 除以上情况,程序退出时可能设置短暂运行10分钟 让程 ...
- 《C++Primer》复习——with C++11 [3]
1.我们的程序经常使用很多IO库,用来输入输出例如:istream(输入流)类型,提供输入操作. ostream(输出流)类型, 提供输出操作. cin, 一个istream对象,从标准输入读取数据. ...
- java多线程为什么要用while而不是if
对于java多线程的wait()方法,我们在jdk1.6的说明文档里可以看到这样一段话 从上面的截图,我们可以看出,在使用wait方法时,需要使用while循环来判断条件十分满足,而不是if,那么我们 ...
- Window7中Eclipse运行MapReduce程序报错的问题
按照文档:http://www.micmiu.com/bigdata/hadoop/hadoop2x-eclipse-mapreduce-demo/安装配置好Eclipse后,运行WordCount程 ...
- d3d11 effect state and default value tables
Blend state State Default ValueAlphaToCoverage Enable FALSEIndependentBlend Enable FALSERenderTarget ...
- ***iOS 项目的目录结构能看出你的开发经验
最近有师弟去面试iOS开发,他谈论到,面试官竟然问他怎么分目录结构的,而且还具体问到每个子目录的文件名. 目录结构确实很重要,面试官问他这些无疑是想窥探他的开发经验.清晰的目录结构,可让人一眼知道对应 ...
- IText 生成页脚页码
做doc文档报表的时候可能遇到这样的需求: 每一个页面需要页码,用IText可以完成这样的需求. IText生成doc文档需要三个包:iTextAsian.jar,iText-rtf-2.1.4.ja ...
- Java中Integer的源码学习
一.开始 public final class Integer extends Number implements Comparable<Integer> 1).由于类修饰符中有关键字 ...
- asp.net中runat="server"的含义
aspx运行时会被编译,其中没有runat server属性的html标签会被直接写入response,有runat server属性的html标签会转换成对应的HtmlControl子类加入 到页面 ...
- 被忽略却很有用的html标签
<base>标签 作用:标签为页面中所有链接指定默认链接地址或链接目标.有时候我们需要让首页的链接全部在新窗口中打开,我们一般会这样写链接,而使用这个标签就能一下搞定了! 属性:Href ...