题目大意:

给定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的更多相关文章

  1. Map Labeler POJ - 2296(2 - sat 具体关系建边)

    题意: 给出n个点  让求这n个点所能建成的正方形的最大边长,要求不覆盖,且这n个点在正方形上或下边的中点位置 解析: 当然是二分,但建图就有点还行..比较难想..行吧...我太垃圾... 2 - s ...

  2. Map Labeler (poj 2296 二分+2-SAT)

    Language: Default Map Labeler Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1815   Ac ...

  3. 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 ...

  4. POJ - 2018 二分+单调子段和

    依然是学习分析方法的一道题 求一个长度为n的序列中的一个平均值最大且长度不小于L的子段,输出最大平均值 最值问题可二分,从而转变为判定性问题:是否存在长度大于等于L且平均值大于等于mid的字段和 每个 ...

  5. POJ 2296 Map Labeler(2-sat)

    POJ 2296 Map Labeler 题目链接 题意: 坐标轴上有N个点.要在每一个点上贴一个正方形,这个正方形的横竖边分别和x,y轴平行,而且要使得点要么在正方形的上面那条边的中点,或者在以下那 ...

  6. poj 3621 二分+spfa判负环

    http://poj.org/problem?id=3621 求一个环的{点权和}除以{边权和},使得那个环在所有环中{点权和}除以{边权和}最大. 0/1整数划分问题 令在一个环里,点权为v[i], ...

  7. POJ 3061 (二分+前缀和or尺取法)

    题目链接: http://poj.org/problem?id=3061 题目大意:找到最短的序列长度,使得序列元素和大于S. 解题思路: 两种思路. 一种是二分+前缀和.复杂度O(nlogn).有点 ...

  8. POJ 2456 (二分)

    题目链接: http://poj.org/problem?id=2456 题目大意:n个房子,m头牛,房子有一个横坐标,问将m头牛塞进房子,每两头牛之间的最大间隔是多少. 解题思路: 不难看出应该二分 ...

  9. POJ 1064 (二分)

    题目链接: http://poj.org/problem?id=1064 题目大意:一堆棍子可以截取,问要求最后给出K根等长棍子,求每根棍子的最大长度.保留2位小数.如果小于0.01,则输出0.00 ...

随机推荐

  1. [css] 自适应布局 移动端自适应

    一.宽度自适应 三列布局左右固定.中间不固定或者两列布局,左边固定右边不固定 原文链接:http://www.cnblogs.com/2050/archive/2012/07/30/2614852.h ...

  2. java实现数据库连接池

    package com.kyo.connection; import java.sql.Connection; import java.sql.DatabaseMetaData; import jav ...

  3. python语法笔记(四)

    1.对象的属性     python一切皆对象,每个对象都可能有多个属性.python的属性有一套统一的管理方案. 属性的__dict__系统     对象的属性可能来自于其类定义,叫做类属性:还可能 ...

  4. 【转】实现RTP协议的H.264视频传输系统

    1.  引言       随着信息产业的发展,人们对信息资源的要求已经逐渐由文字和图片过渡到音频和视频,并越来越强调获取资源的实时性和互动性.但人们又面临着另外一种不可避免的尴尬,就是在网络上看到生动 ...

  5. 【bzoj1043】下落的圆盘

    [bzoj1043]下落的圆盘 题意 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求. \(1\leq n\leq 1000\ ...

  6. css选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先

    通配选择符* { sRules }  类型选择符E { sRules }  td { font-size:14px; width:120px; }   属性选择符 E [ attr ] { sRule ...

  7. robotframework笔记10

    循环和条件 for循环 *** Settings *** Library BuiltIn Library Collections *** Test Cases *** TestCase01 My Ke ...

  8. valuestack,stackContext,ActionContext.之间的关系

    者之间的关系如下图所示: relation ActionContext 一次Action调用都会创建一个ActionContext 调用:ActionContext context = ActionC ...

  9. 你不知道的JavaScript--面向对象高级程序设计

    转载http://blog.csdn.net/i10630226/article/details/51088841 1. JS是基于原型的程序 建立一个简单的面向对象的类.有属性,有方法. funct ...

  10. web开发必须知道的javascripat工具

    1,JavaScript compressor and comparison tool 有许多工具可以帮助你压缩JavaScript代码,但是这个过程比较耗时,并且,对于某个特定的场景来说,很难分析出 ...