题目大意:

·给你一个n,表示输入n个白点和n个黑点(输入每一个点的坐标)。现在需要将各个白点和各个黑点一一用线段连接起来,需要满足这些线段不能够相交。

·特色:

我们如何保证线段间不相交。

·分析:

由“黑白”可以想到用二分图匹配(最大流问题亦可)。用到一个神秘结论,可以巧妙地将“相交”和“不相交”转化为具体数值大小关系,进而转化为权值。结论为:【四边形两条对角线的和必定大于它任何一组对边的和】

用一下这幅图进行分析:

         

下面来比较线段交叉和不交叉情况下,两条线段和的大小:

①交叉线段:(蓝色线段)

D1=dis(A,C)+dis(B,D)

    =(a2-a1)2+Y2+(b2-b1)2+X2

②非交叉线段(这里计算AB,CD,其余情况可以用对称性等价得到)

D2=dis(A,B)+dis(C,D)

     =a12+b12+(X-a2)2+(Y-b2)2

【作差】:

D1-D2=dis(A,C)+dis(B,D)-dis(A,B)-dis(C,D)

           =2*b2(Y-b1)+2*a2(X-a1)

【结论】:

由于Y==b1与X==a1同时满足是不可能的(点重合了!)

又因为Y>=b1,X>=a1所以上面D1-D2的式子必为正数。

这意味着D1恒大于D2。因此这需要我们进行最小权值的二分图完全匹配。

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<cstring>
4 #include<cmath>
5 #define go(i,a,b) for(int i=a;i<=b;i++)
6 #define fo(i,a,x) for(int i=a[x],v=e[i].v;i>-1;i=e[i].next,v=e[i].v)
7 #define mem(a,b) memset(a,b,sizeof(a))
8 #define inf 200000000
9 #define eps 0.000001
10 using namespace std;const int N=1003
;
11 struct POS{double
x,y;}white[N],black[N];
12 struct E{int v,next;double w;}e[N*
N];
13 int
n,head[N],k,c[N],S[N],T[N];
14 void ADD(int u,int v,double w){e[k]=(E){v,head[u],w};head[u]=k++
;}
15 double A(double x){return x*x;};double
slack[N],Lx[N],Ly[N];
16 double dis(POS a,POS b){return sqrt(A(a.x-b.x)+A(a.y-
b.y));}
17 bool aug(int
u){
18 S[u]=1;fo(i,head,u)if(!
T[v])
19 {double t=Lx[u]+Ly[v]-e[i].w;if(t<eps&&t>-
eps)
20 {T[v]=1;if(!c[v]||aug(c[v])){c[v]=u;return 1
;}}
21 else slack[v]=min(slack[v],t);}return 0
;
22
}
23 void revise(){double a=
inf;
24 go(i,1,n)if(!T[i])a=
min(a,slack[i]);
25 go(i,1,n)S[i]?Lx[i]-=a,1:1,T[i]?Ly[i]+=a,1:1
;
26
}
27 int main(){while(~scanf("%d",&
n)){
28 mem(head,-1);k=0
;
29 go(i,1,n)scanf("%lf%lf",&white[i].x,&
white[i].y);
30 go(i,1,n)scanf("%lf%lf",&black[i].x,&
black[i].y);
31 go(i,1,n)go(j,1,n)ADD(i,j,-
dis(white[i],black[j]));
32
33 go(u,1,n){Ly[u]=c[u]=0;Lx[u]=-
inf;
34 fo(i,head,u)Lx[u]=
max(Lx[u],e[i].w);}
35
36 go(i,1,n){go(j,1,n)slack[j]=
inf;
37 for(;;){go(j,1,n)S[j]=T[j]=0
;
38 if(aug(i))break;else
revise();}}
39
40 go(i,1,n)go(j,1,n)if(c[j]==
i)
41 {printf("%d\n",j);break
;}
42 }return 0;}//Paul_Guderian

【大米饼代码】

我看见了一条河。

【uva 1411 Ants蚂蚁们】的更多相关文章

  1. UVA 1411 - Ants(二分图完美匹配)

    UVA 1411 - Ants 题目链接 题意:给定一些黑点白点,要求一个黑点连接一个白点,而且全部线段都不相交 思路:二分图完美匹配,权值存负的欧几里得距离,这种话,相交肯定比不相交权值小,所以做一 ...

  2. uva 1411 Ants (权值和最小的完美匹配---KM算法)

    uva 1411 Ants Description Young naturalist Bill studies ants in school. His ants feed on plant-louse ...

  3. UVA 10714 Ants 蚂蚁 贪心+模拟 水题

    题意:蚂蚁在木棍上爬,速度1cm/s,给出木棍长度和每只蚂蚁的位置,问蚂蚁全部下木棍的最长时间和最短时间. 模拟一下,发现其实灰常水的贪心... 不能直接求最大和最小的= =.只要求出每只蚂蚁都走长路 ...

  4. UVa 1411 Ants(分治)

    https://vjudge.net/problem/UVA-1411 题意:n只蚂蚁和n颗苹果树,一一配对并且不能交叉. 思路:这就是巨人与鬼的问题.用分治法就行了. #include<ios ...

  5. poj 3565 uva 1411 Ants KM算法求最小权

    由于涉及到实数,一定,一定不能直接等于,一定,一定加一个误差<0.00001,坑死了…… 有两种事物,不难想到用二分图.这里涉及到一个有趣的问题,这个二分图的完美匹配的最小权值和就是答案.为啥呢 ...

  6. uva 1411 Ants

    题意: 一个平面上有n个黑色的点,n个白色的点,要求黑色的点与白色点之间一一配对,且线段之间不相交. 思路: 线段不相交并不好处理,想了很久想不出,所以看了蓝书的讲解. 一个很明显的结论是,不相交的线 ...

  7. 【UVA 1411】 Ants (KM)

    Young naturalist Bill studies ants in school. His ants feed onplant-louses that live on apple trees. ...

  8. cogs 1456. [UVa 10881,Piotr's Ants]蚂蚁

    1456. [UVa 10881,Piotr's Ants]蚂蚁 ★   输入文件:Ants.in   输出文件:Ants.out   简单对比时间限制:1 s   内存限制:128 MB [题目描述 ...

  9. [ACM_模拟] UVA 10881 Piotr's Ants[蚂蚁移动 数组映射 排序技巧]

    "One thing is for certain: there is no stopping them;the ants will soon be here. And I, for one ...

随机推荐

  1. 翻译:CREATE FUNCTION语句(已提交到MariaDB官方手册)

    本文为mariadb官方手册:CREATE FUNCTION的译文. 原文:https://mariadb.com/kb/en/library/create-function/我提交到MariaDB官 ...

  2. dede使用心得

    Question one: 最近做了一些视频教程传到优酷网站上,但我想引入这些视频教程到我的网站,在发表时我发现织梦CMS自带的编辑器又不直接支持优酷等视频网站的引用.所以为了方便教程的发布,特意在网 ...

  3. LeetCode & Q189-Rotate Array-Easy

    Array Description: Rotate an array of n elements to the right by k steps. For example, with n = 7 an ...

  4. Java 持久化操作之 --io流与序列化

    1)File类操作文件的属性 1.File类的常用方法 1. 文件的绝对完整路径:getAbsolutePath() 文件名:getName() 文件相对路径:getPath() 文件的上一级目录:g ...

  5. 用Vue.js开发微信小程序:开源框架mpvue解析

    前言 mpvue 是一款使用 Vue.js 开发微信小程序的前端框架.使用此框架,开发者将得到完整的 Vue.js 开发体验,同时为 H5 和小程序提供了代码复用的能力.如果想将 H5 项目改造为小程 ...

  6. JAVA 中一个非常轻量级只有 200k 左右的 RESTful 路由框架

    ICEREST 是一个非常轻量级只有 200k 左右的 RESTful 路由框架,通过 ICEREST 你可以处理 url 的解析,数据的封装, Json 的输出,和传统的方法融合,请求的参数便是方法 ...

  7. Apollo单向SSL认证(1)

    参考链接:https://www.cnblogs.com/benwu/articles/4891758.html keytool -genkey -alias mybroker -keyalg RSA ...

  8. spring-oauth-server实践:授权方式四:client_credentials 模式下access_token的产生

    授权结果 获取access_token成功, 访问资源服务器API http://localhost:9000/api-gateway-engine/unity/user_info?access_to ...

  9. powerdesigner将name的名字赋给comment

    1 PowerDesigner中批量根据对象的name生成comment的脚本 执行方法:Open PDM -- Tools -- Execute Commands -- Run Script Vb ...

  10. hdu1003 Max Sum---最大子段和+记录开始结束点

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1003 题目大意: 求最大子段和,并且输出最大子段和的起始位置和终止位置. 思路: 根据最大子段和基本 ...