POJ 2296 二分+2-sat
题目大意:
给定n个点,给每个点都安排一个相同的正方形,使这个点落在正方形的下底边的中间或者上底边的中间,并让这n个正方形不出现相互覆盖,可以共享同一条边,求
这个正方形最大的边长
这里明显看出n个点,每个点都只有在上底边和下底边两种选择,所以这里是2-sat解决
这里全都是整数,而因为点在正方形的中间,所以/2后会有小数
我这里初始将所有点都扩大两倍,那么答案必然扩大两倍,所以我们二分只考虑边长为偶数的情况即可,这样计算结果就不会出现小数了
最后将答案除以2便是
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std; #define N 210
int n , S[N] , x[N] , y[N] , k;
vector<int> G[N];
bool mark[N]; struct Rec{
int x[] , y[];
bool in(Rec a){
if(a.x[]>=x[] || a.y[]>=y[] || a.x[]<=x[] || a.y[]<=y[]) return false;
return true;
}
}a , b , c , d; void init(int n)
{
memset(mark , , sizeof(mark));
for(int i= ; i<*n ; i++) G[i].clear();
} bool dfs(int u)
{
if(mark[u]) return true;
if(mark[u^]) return false;
mark[u] = true;
S[k++] = u;
for(int i= ; i<G[u].size() ; i++)
if(!dfs(G[u][i])) return false;
return true;
} bool solve(int n)
{
for(int i= ; i<*n ; i+=)
if(!mark[i] && !mark[i^]){
k= ;
if(!dfs(i)){
while(k) mark[S[--k]] = false;
if(!dfs(i^)) return false;
}
}
return true;
} void add_clause(int a , int p , int b , int q)
{
int m=*a+p;
int n=*b+q;
//m,n互斥
G[m].push_back(n^);
G[n].push_back(m^);
} bool check(int m)
{
init(n);
if(m&) m--;
for(int i= ; i<n ; i++){
for(int j=i+ ; j<n ; j++){
//down , up 2*2 four case
a.x[] = x[i]-m/ , a.y[] = y[i];
a.x[] = x[i]+m/ , a.y[] = y[i];
a.x[] = a.x[] , a.y[] = y[i]+m;
a.x[] = a.x[] , a.y[] = y[i]+m; b.x[] = x[j]-m/ , b.y[] = y[j];
b.x[] = x[j]+m/ , b.y[] = y[j];
b.x[] = b.x[] , b.y[] = y[j]+m;
b.x[] = b.x[] , b.y[] = y[j]+m; c.x[] = x[i]-m/ , c.y[] = y[i]-m;
c.x[] = x[i]+m/ , c.y[] = y[i]-m;
c.x[] = c.x[] , c.y[] = y[i];
c.x[] = c.x[] , c.y[] = y[i]; d.x[] = x[j]-m/ , d.y[] = y[j]-m;
d.x[] = x[j]+m/ , d.y[] = y[j]-m;
d.x[] = d.x[] , d.y[] = y[j];
d.x[] = d.x[] , d.y[] = y[j]; if(a.in(b)) add_clause(i , , j , );
if(a.in(d)) add_clause(i , , j , );
if(c.in(b)) add_clause(i , , j , );
if(c.in(d)) add_clause(i , , j , );
}
}
return solve(n);
} int main()
{
// freopen("in.txt" , "r" , stdin);
int T;
scanf("%d" , &T);
while(T--)
{
scanf("%d" , &n);
for(int i= ; i<n ; i++){
scanf("%d%d" , &x[i] , &y[i]);
x[i]*= , y[i]*=;
}
int l= , r=1e5 , ret=l;
while(l<=r){
int m = (l+r)>>;
if(check(m)) ret=m , l=m+;
else r=m-;
}
printf("%d\n" , ret/);
}
return ;
}
POJ 2296 二分+2-sat的更多相关文章
- Map Labeler POJ - 2296(2 - sat 具体关系建边)
题意: 给出n个点 让求这n个点所能建成的正方形的最大边长,要求不覆盖,且这n个点在正方形上或下边的中点位置 解析: 当然是二分,但建图就有点还行..比较难想..行吧...我太垃圾... 2 - s ...
- Map Labeler (poj 2296 二分+2-SAT)
Language: Default Map Labeler Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1815 Ac ...
- POJ 2296 Map Labeler / ZOJ 2493 Map Labeler / HIT 2369 Map Labeler / UVAlive 2973 Map Labeler(2-sat 二分)
POJ 2296 Map Labeler / ZOJ 2493 Map Labeler / HIT 2369 Map Labeler / UVAlive 2973 Map Labeler(2-sat ...
- POJ - 2018 二分+单调子段和
依然是学习分析方法的一道题 求一个长度为n的序列中的一个平均值最大且长度不小于L的子段,输出最大平均值 最值问题可二分,从而转变为判定性问题:是否存在长度大于等于L且平均值大于等于mid的字段和 每个 ...
- POJ 2296 Map Labeler(2-sat)
POJ 2296 Map Labeler 题目链接 题意: 坐标轴上有N个点.要在每一个点上贴一个正方形,这个正方形的横竖边分别和x,y轴平行,而且要使得点要么在正方形的上面那条边的中点,或者在以下那 ...
- poj 3621 二分+spfa判负环
http://poj.org/problem?id=3621 求一个环的{点权和}除以{边权和},使得那个环在所有环中{点权和}除以{边权和}最大. 0/1整数划分问题 令在一个环里,点权为v[i], ...
- POJ 3061 (二分+前缀和or尺取法)
题目链接: http://poj.org/problem?id=3061 题目大意:找到最短的序列长度,使得序列元素和大于S. 解题思路: 两种思路. 一种是二分+前缀和.复杂度O(nlogn).有点 ...
- POJ 2456 (二分)
题目链接: http://poj.org/problem?id=2456 题目大意:n个房子,m头牛,房子有一个横坐标,问将m头牛塞进房子,每两头牛之间的最大间隔是多少. 解题思路: 不难看出应该二分 ...
- POJ 1064 (二分)
题目链接: http://poj.org/problem?id=1064 题目大意:一堆棍子可以截取,问要求最后给出K根等长棍子,求每根棍子的最大长度.保留2位小数.如果小于0.01,则输出0.00 ...
随机推荐
- RTC框架
RPC是系统间的一种通信方式,系统间常用的通信方式还有http,webservice,rpc等,一般来讲rpc比http和webservice性能高一些,常见的RPC框架有:thrift,Finagl ...
- 转!!java反射机制
Java 反射机制 基本概念 在Java运行时环境中,对于任意一个类,能否知道这个类有哪些属性和方法?对于任意一个对象,能否调用它的任意一个方法? 答案是肯定的. 这种动态获取类的信息以及动态调用对象 ...
- javascript强制转换详解
转换成数值 Number函数强制转换成数值 数值->转换成原来的值 字符串->如果可以解析为数值,则转换成数值:否则转换成NaN或者0 true->1,falSe->0 und ...
- 【转】loading 三种实现方式
转载:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=76872 一.通过动画实现 定义res/anim/loading.xml如 ...
- c time_t 和 oc NSDate 的转换
c time_t 和 oc NSDate 的转换 1:time_t 转 oc NSDate time_t some_time_t=NULL; NSDate *someDate = [NSDate da ...
- 慎用GetOpenFileName
这两天发现了一个小问题,经过一上午的排查终于找到了问题的原因--Windows 7的API函数GetOpenFileName竟然有BUG! 请参考下面的MFC代码: CFileDialog dlg(T ...
- Windows定时器
目录 第1章定时器 1 1.1 创建定时器 1 1.2 销毁定时器 1 1.3 定时器的运作 1 1.3.1 产生WM_TIMER消息 1 1.3.2 分发WM_TIME ...
- js中的apply和call API
借用网上的一个例子: fun.call(this,arg1,arg2,arg3) fun.apply(this,arguments) this.fun(arg1,arg2,arg3) 三种方法等效. ...
- [转载]SOAPUI压力测试的参数配置
原文地址:SOAPUI压力测试的参数配置作者:goooooodlife The different Load Strategies available in soapUI and soapUI Pro ...
- (12)odoo各种提前期和时间
1)Product的提前期 Customer Lead Time(sale_delay):客户提前期,指SO确认到向客户发货的天数,由于销售数量不同该时间也不同,因此,这里是一个平均时间. ...