Building roads
Time Limit: 2000MS   Memory Limit: 65536K
Total Submissions: 8153   Accepted: 2772

Description

Farmer John's farm has N barns, and there are some cows that live in each barn. The cows like to drop around, so John wants to build some roads to connect these barns. If he builds roads for every pair of different barns, then he must build N * (N - 1) / 2 roads, which is so costly that cheapskate John will never do that, though that's the best choice for the cows.

Clever John just had another good idea. He first builds two
transferring point S1 and S2, and then builds a road connecting S1 and
S2 and N roads connecting each barn with S1 or S2, namely every barn
will connect with S1 or S2, but not both. So that every pair of barns
will be connected by the roads. To make the cows don't spend too much
time while dropping around, John wants to minimize the maximum of
distances between every pair of barns.

That's not the whole story because there is another troublesome
problem. The cows of some barns hate each other, and John can't connect
their barns to the same transferring point. The cows of some barns are
friends with each other, and John must connect their barns to the same
transferring point. What a headache! Now John turns to you for help.
Your task is to find a feasible optimal road-building scheme to make the
maximum of distances between every pair of barns as short as possible,
which means that you must decide which transferring point each barn
should connect to.

We have known the coordinates of S1, S2 and the N barns, the pairs
of barns in which the cows hate each other, and the pairs of barns in
which the cows are friends with each other.

Note that John always builds roads vertically and horizontally, so
the length of road between two places is their Manhattan distance. For
example, saying two points with coordinates (x1, y1) and (x2, y2), the
Manhattan distance between them is |x1 - x2| + |y1 - y2|.

Input

The
first line of input consists of 3 integers N, A and B (2 <= N <=
500, 0 <= A <= 1000, 0 <= B <= 1000), which are the number
of barns, the number of pairs of barns in which the cows hate each other
and the number of pairs of barns in which the cows are friends with
each other.

Next line contains 4 integer sx1, sy1, sx2, sy2, which are the
coordinates of two different transferring point S1 and S2 respectively.

Each of the following N line contains two integer x and y. They are
coordinates of the barns from the first barn to the last one.

Each of the following A lines contains two different integers i and
j(1 <= i < j <= N), which represent the i-th and j-th barns in
which the cows hate each other.

The same pair of barns never appears more than once.

Each of the following B lines contains two different integers i and
j(1 <= i < j <= N), which represent the i-th and j-th barns in
which the cows are friends with each other. The same pair of barns never
appears more than once.

You should note that all the coordinates are in the range [-1000000, 1000000].

Output

You
just need output a line containing a single integer, which represents
the maximum of the distances between every pair of barns, if John
selects the optimal road-building scheme. Note if there is no feasible
solution, just output -1.

Sample Input

4 1 1
12750 28546 15361 32055
6706 3887
10754 8166
12668 19380
15788 16059
3 4
2 3

Sample Output

53246

Source

[Submit]   [Go Back]   [Status]   [Discuss]

考虑二分答案,然后根据题目给出的限制以及这个二分出来的距离限制建图,2-SAT解决。

 #include<cstdio>
#include<cstring>
#include<algorithm>
#define mem(a) memset(a,0,sizeof(a))
#define rep(i,l,r) for (int i=(l); i<=(r); i++)
#define For(i,x) for (int i=h[x],k; i; i=nxt[i])
using namespace std; const int N=,M=N*N*;
int a,b,n,mx,ans,cnt,scc,top,L,R,tim,dis,x1,y1,x2,y2,x,y,dis1[N],dis2[N],ax[N],ay[N],bx[N],by[N];
int to[M],nxt[M],q[N],dfn[N],inq[N],h[N],low[N],bel[N];
void add(int u,int v){ to[++cnt]=v; nxt[cnt]=h[u]; h[u]=cnt; } void init(){ cnt=top=scc=tim=; mem(h); mem(dfn); mem(inq); } int cal(int x1,int y1,int x2,int y2){ return abs(x2-x1)+abs(y2-y1); } void tarjan(int x){
dfn[x]=low[x]=++tim; inq[x]=; q[++top]=x;
For(i,x) if (!dfn[k=to[i]]) tarjan(k),low[x]=min(low[x],low[k]);
else if (inq[k]) low[x]=min(low[x],dfn[k]);
if (dfn[x]==low[x]){
scc++; int t;
do { t=q[top--]; bel[t]=scc; inq[t]=; }while(t!=x);
}
} bool jud(int mid){
init();
rep(i,,n) rep(j,i+,n){
if (dis1[i]+dis1[j]>mid) add(i,n+j),add(j,n+i);
if (dis2[i]+dis2[j]>mid) add(i+n,j),add(j+n,i);
if (dis1[i]+dis2[j]+dis>mid) add(i,j),add(j+n,i+n);
if (dis2[i]+dis1[j]+dis>mid) add(i+n,j+n),add(j,i);
}
rep(i,,a) add(ax[i],ay[i]+n),add(ay[i]+n,ax[i]),add(ay[i],ax[i]+n),add(ax[i]+n,ay[i]);
rep(i,,b) add(bx[i],by[i]),add(by[i],bx[i]),add(bx[i]+n,by[i]+n),add(by[i]+n,bx[i]+n);
rep(i,,*n) if (!dfn[i]) tarjan(i);
rep(i,,n) if (bel[i]==bel[i+n]) return ;
return ;
} int main(){
freopen("poj2749.in","r",stdin);
freopen("poj2749.out","w",stdout);
while (~scanf("%d%d%d",&n,&a,&b)){
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
dis=cal(x1,y1,x2,y2); mx=;
rep(i,,n){
scanf("%d%d",&x,&y);
dis1[i]=cal(x,y,x1,y1); dis2[i]=cal(x,y,x2,y2);
mx=max(mx,max(dis1[i],dis2[i]));
}
mx=mx*+dis;
rep(i,,a) scanf("%d%d",&ax[i],&ay[i]);
rep(i,,b) scanf("%d%d",&bx[i],&by[i]);
int L=,R=mx; ans=-;
while (L<=R){
int mid=(L+R)>>;
if (jud(mid)) ans=mid,R=mid-; else L=mid+;
}
printf("%d\n",ans);
}
return ;
}

[POJ2749]Building roads(2-SAT)的更多相关文章

  1. POJ2749 Building roads

    嘟嘟嘟 最近把21天漏的给不上. 今天重温了一下2-SAT,感觉很简单.就是把所有条件都转化成如果--必然能导出--.然后就这样连边建图,这样一个强连通分量中的所有点必然都是真或者假.从而根据这个点拆 ...

  2. POJ2749 Building roads 【2-sat】

    题目 Farmer John's farm has N barns, and there are some cows that live in each barn. The cows like to ...

  3. poj 3625 Building Roads

    题目连接 http://poj.org/problem?id=3625 Building Roads Description Farmer John had just acquired several ...

  4. poj 2749 Building roads (二分+拆点+2-sat)

    Building roads Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 6229   Accepted: 2093 De ...

  5. BZOJ 1626: [Usaco2007 Dec]Building Roads 修建道路( MST )

    计算距离时平方爆了int结果就WA了一次...... ------------------------------------------------------------------------- ...

  6. HDU 1815, POJ 2749 Building roads(2-sat)

    HDU 1815, POJ 2749 Building roads pid=1815" target="_blank" style="">题目链 ...

  7. Building roads

    Building roads Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...

  8. bzoj1626 / P2872 [USACO07DEC]道路建设Building Roads

    P2872 [USACO07DEC]道路建设Building Roads kruskal求最小生成树. #include<iostream> #include<cstdio> ...

  9. bzoj 1626: [Usaco2007 Dec]Building Roads 修建道路 -- 最小生成树

    1626: [Usaco2007 Dec]Building Roads 修建道路 Time Limit: 5 Sec  Memory Limit: 64 MB Description Farmer J ...

随机推荐

  1. 【BZOJ】4316: 小C的独立集 静态仙人掌

    [题意]给定仙人掌图,求最大独立集(选择最大的点集使得点间无连边).n<=50000,m<=60000. [算法]DFS处理仙人掌图 [题解]参考:[BZOJ]1023: [SHOI200 ...

  2. ActiveMQ笔记之点对点队列(Point-to-Point)

    1. 点对点通信 点对点是一种一对一通信方式,更像是有一个队列,一个人往队列里放消息,另一个人从队列中取消息,其最大的特点是一个消息只会被消费一次,即使有多个消费者同时消费,他们消费的也是不同的消息. ...

  3. jQuery实现简单前端搜索功能

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 用CRF做命名实体识别(一)

    用CRF做命名实体识别(二) 用CRF做命名实体识别(三) 用BILSTM-CRF做命名实体识别 博客园的markdown格式可能不太方便看,也欢迎大家去我的简书里看 摘要 本文主要讲述了关于人民日报 ...

  5. Supply

    Supplier创建一个Supply Supply有tap或emit方法. 可以这样理解: Supplier创建一个工厂 Supply 用tap创建流水线 emit向流水线上传送加工品进行加厂 my ...

  6. Fedora8 U盘安装

    (一)分区 在XP下"我的电脑“管理功能,对硬盘分区,目的是从逻辑分区中拿出20G空间,分成3个盘(必须为逻辑盘): (1)512MB   用作Linux swap分区: (2)200MB  ...

  7. linux initcall 介绍 (转自http://blog.csdn.net/fenzhikeji/article/details/6860143)

    现在以module_init为例分析initcall在内核中的调用顺序 在头文件init.h中,有如下定义: #define module_init(x)     __initcall(x); 很明显 ...

  8. bootstrap table 双击可编辑,添加、删除行

    html: <table class="table table-bordered" id="para_table"> <tr> < ...

  9. 牛奶ddw如何通过以太坊钱包实现互相打赏

    很多朋友不清楚如何转账ddw,但是万能的网友是无敌的,这两天就自己摸索的一点经验总结下今天的转账经验. 1. 提取到自己的账户 这个大家都知道如何操作,使用官方的钱包 在“日日盈app”中点击&quo ...

  10. mysql 配置数据库主从同步

    参考:https://www.cnblogs.com/kevingrace/p/6256603.html http://www.51testing.com/html/00/130600-243651. ...