Poj2296
题意:给定n个点,然后在每个点在一个正方形的上边或者下边的中点,并且所有的正方形等大且不能重叠。求正方形最大的边长是多少。
思路:很明显的二分边长+判定。不过判定要用到2-sat,算是2-sat的入门题吧。
所谓的2-sat,就是对于若干个bool不等式,然后对于会互相干扰(即不能同时成立的),连边处理,然后对于每一块枚举一个点的值,判断是否可行。出现冲突即无解。具体看代码吧。
下面2-sat部分是LRJ的模板,写的挺清晰的。。
/*
* Author: Yzcstc
* Created Time: 2014/3/8 13:40:50
* File Name: Poj2296.cpp
*/
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<string>
#include<map>
#include<set>
#include<vector>
#include<queue>
#include<stack>
#include<ctime>
#define M0(x) memset(x, 0, sizeof(x))
#define rep(i, a, b) for (int i = (a); i <= (b); ++i)
#define red(i, a, b) for (int i = (a); i >= (b); --i)
#define PB push_back
#define Inf 0x3fffffff
#define eps 1e-8
#define maxn 500
typedef long long LL;
using namespace std;
struct TwoSat{
int n;
vector<int> G[maxn * ];
bool mark[maxn * ];
int S[maxn * ], c;
bool dfs(int x){ // 搜索一组解
if (mark[x^]) return false; //出现冲突
if (mark[x]) return true;
mark[x] = true;
S[c++] = x;
for (int i = ; i < G[x].size(); ++i)
if (!dfs(G[x][i])) return false;
return true;
} void init(int n){
this->n = n;
for (int i = ; i < * n; ++i)
G[i].clear();
memset(mark, , sizeof(mark));
} void add_clause(int x, int xv, int y, int yv){
x = x * + xv;
y = y * + yv; //x,y不能同时存在,那么如果选了y,合法解必定要选x^1
G[x^].push_back(y);
G[y^].push_back(x);
} bool solve(){
for (int i = ; i < n * ; i += )
if (!mark[i] && !mark[i+]){
c = ;
if (!dfs(i)){ //枚举2种取值都无解
while (c > ) mark[S[--c]] = false;
if (!dfs(i+)) return false;
}
}
return true;
}
} Sat; int n, X[], Y[], T; void init(){
scanf("%d", &n);
for (int i = ; i < n; ++i)
scanf("%d%d", &X[i], &Y[i]);
} bool check(int r){
Sat.init(n);
for (int i = ; i < n; ++i)
for (int j = i + ; j < n; ++j) if (i != j){ //分类讨论冲突情况
if (Y[i] < Y[j]){
if (Y[j] - Y[i] < r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
if (Y[j] - Y[i] < * r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
if (Y[j] - Y[i] < r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
}
if (Y[i] > Y[j]){
if (Y[i] - Y[j] < r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
if (Y[i] - Y[j] < * r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
if (Y[i] - Y[j] < r && abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
}
if (Y[i] == Y[j]){
if (abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
if (abs(X[i] - X[j]) < r) Sat.add_clause(i, , j, );
}
}
return Sat.solve();
} void solve(){
int l = , r = , mid;
int cnt = , ans = ;
while (l <= r){ //二分答案
mid = (l + r) >> ;
if (check(mid)) { ans = mid, l = mid + ;}
else r = mid - ;
}
printf("%d\n",ans);
} int main(){
freopen("a.in", "r", stdin);
freopen("a.out", "w", stdout);
scanf("%d", &T);
while (T--){
init();
solve();
}
fclose(stdin); fclose(stdout);
return ;
}
Poj2296的更多相关文章
- POJ-2296 Map Labeler 2sat
题目链接:http://poj.org/problem?id=2296 二分+2sat,每个点的上下两个方向为2sat的两个状态. //STATUS:C++_AC_16MS_536KB #includ ...
- POJ2296二分2sat
题意: 给n个点,每个点必须在一个正方形上,可以在正方向上面边的中点或者是下面边的中点,正方形是和x,y轴平行的,而且所有的点的正方形的边长一样,并且正方形不能相互重叠(边相邻可以),问满 ...
- OJ题目分类
POJ题目分类 | POJ题目分类 | HDU题目分类 | ZOJ题目分类 | SOJ题目分类 | HOJ题目分类 | FOJ题目分类 | 模拟题: POJ1006 POJ1008 POJ1013 P ...
- 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 ...
- 关于2-sat的建图方法及解决方案
转载增减: https://blog.csdn.net/qq_24451605/article/details/47126143 https://blog.csdn.net/u012915516/ar ...
- 2-Sat小结
关于2-sat,其实就是一些对于每个问题只有两种解,一般会给出问题间的关系,比如and,or,not等关系,判定是否存在解的问题.. 具体看http://blog.csdn.net/jarjingx/ ...
- 专题训练之2-sat
推荐几篇博客:https://blog.csdn.net/JarjingX/article/details/8521690 研究总结2-sat问题 https://blog.csdn.net/wher ...
随机推荐
- andorid 数据储存
.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android ...
- 清晰易懂!关于PS入门的超详细笔记!
给大家分享一篇关于PS入门的超详细笔记!原理讲解清晰明了,虽不是新版本解析,但都是新手学习PS必掌懂的一些知识点,灰常的实用,转走收藏学习! 编辑:千锋UI设计 来源:PS学堂
- XSS绕过速查表
0x00 目录 0x01 常规插入及其绕过 1 Script 标签 绕过进行一次移除操作: <scr<script>ipt>alert("XSS")< ...
- swift 官方获取JSON 数据方法
var url = NSURL(string: "http://www.weather.com.cn/data/sk/101120501.html") var data = NSD ...
- mysql完装成功后的提示。
To start mysqld at boot time you have to copysupport-files/mysql.server to the right place for your ...
- Tomcat优化详细1
在Tomcat和应用程序进行了压力测试后,如果您对应用程序的性能结果不太满意,就可以采取一些性能调整措施了,当然了前提是应用程序没有问题,我们这里只讲Tomcat的调整.由于Tomcat的运行依赖于J ...
- JavaScript中hasOwnProperty函数
JavaScript中hasOwnProperty函数方法是返回一个布尔值,指出一个对象是否具有指定名称的属性. 使用方法: object.hasOwnProperty(proName) 其中参数 ...
- HYSBZ - 3676
模板题.问你一个串里最大的值(回文子串*出现次数) /* gyt Live up to every day */ #include<cstdio> #include<cmath> ...
- BP神经网络测试MNIST记录
约定: 所有的初始化权值范围,如下,就是说更换激活函数的情况,没有过大的调整初始权重. if(randomMode==1): numpy.random.seed(seedWih) self.wih = ...
- 异常处理(异常解析器) 和 对于Properties类型的属性的配置
在程序运行中,有可能因为用户的不当操作,发生异常.. 在springmvc中可以根据不同的异常配置不同的处理方式 1.例如出现 这个类型异常 org.springframework.web.multi ...