ZOJ 3717
这题是二分+2SAT.
总结一下SAT题的特征。首先,可能会存在二选一的情况,然后会给出一些矛盾。据这些矛盾加边,再用SAT判定。
这一道题好像不能直接用printf("%0.3lf"),因为这个是四舍五入的,这道题好像不能四舍五入,只好选减去0.0005再按这个格式输出了。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <stdlib.h>
#define oo 1000000007
#define eps 1e-4
using namespace std;
const int MAXN=;
const int MAXM=;
struct b{
int x,y,z;
}ball[MAXN];
double dis[MAXN][MAXN];
int head[MAXN],dfn[MAXN],low[MAXN],tot,stop,indx,belong[MAXN],pat;
int st[MAXN];
bool stack[MAXN];
int n;
struct e{
int u,v;
int next;
}edge[MAXM]; void addedge(int u,int v){
edge[tot].u=u;
edge[tot].v=v;
edge[tot].next=head[u];
head[u]=tot++;
} void tarjan(int u){
int v;
dfn[u]=low[u]=++indx;
st[stop++]=u;
stack[u]=true;
for (int e=head[u];e!=-;e=edge[e].next){
v=edge[e].v;
if (dfn[v]==) {
tarjan(v) ;
low[u] = min(low[u], low[v]) ;
}
else if (stack[v]) {
low[u] = min(low[u], dfn[v]) ;
}
}
if (dfn[u] == low[u]) {
pat++;
do{
v = st[--stop];
belong[v]=pat;
stack[v]=false;
}while(u!= v);
}
} bool slove(double leng){
int a,b; tot=; indx=; stop=; pat=-;
memset(head,-,sizeof(head));
for(int i=;i<n;i++){
a=i;
for(int j=i+;j<n;j++){
b=j;
if(leng*>dis[a*][b*]){
addedge(*a+,b*);
addedge(b*+,a*);
}
if(leng*>dis[a*][b*+]){
addedge(a*+,b*+);
addedge(b*,a*);
}
if(leng*>dis[a*+][b*]){
addedge(a*,b*);
addedge(b*+,a*+);
}
if(leng*>dis[a*+][b*+]){
addedge(a*,b*+);
addedge(b*,a*+);
}
}
}
memset(dfn,,sizeof(dfn));
memset(low,,sizeof(low));
memset(stack,false,sizeof(stack));
memset(belong,-,sizeof(belong));
for(int i=;i<*n;i++){
if(dfn[i]==){
tarjan(i);
}
}
bool flag=true;
for(int i=;i<n;i++){
if(belong[i*]==belong[i*+]){
flag=false;
break;
}
}
return flag;
} int main(){
double xi,yi,zi;
while(scanf("%d",&n)!=EOF){
for(int i=;i<*n;i++){
scanf("%d%d%d",&ball[i].x,&ball[i].y,&ball[i].z);
i++;
scanf("%d%d%d",&ball[i].x,&ball[i].y,&ball[i].z);
}
double high=oo,lown=; double tmp;
for(int i=;i<*n;i++){
for(int j=i;j<*n;j++){
xi=ball[i].x-ball[j].x;
yi=ball[i].y-ball[j].y;
zi=ball[i].z-ball[j].z;
tmp=sqrt(xi*xi+yi*yi+zi*zi);
dis[i][j]=dis[j][i]=tmp;
}
}
double ans;
while(lown<high-eps){
double mid=(high+lown)/;
if(slove(mid)){
ans=mid;
lown=mid;
}
else high=mid;
}
printf("%0.3lf\n",ans-0.0005);
}
return ;
}
ZOJ 3717的更多相关文章
- zoj 3717 - Balloon(2-SAT)
裸的2-SAT,详见刘汝佳训练指南P-323 不过此题有个特别需要注意的地方:You should promise that there is still no overlap for any two ...
- ZOJ 3717 Balloon ( TLE )
正解2-SAT. 我用DLX想搜一搜的,结果TLE了…… 没什么遗憾,最起码我尝试过了. 扔个代码留作纪念. #include <cstdio> #include <cstring& ...
- ZOJ 3717 二分+2-sat判定。
好久没有2-sat了,此题当复习之用,二分求最大值+2-sat判断可行,此题主要跪于题意:The results should be rounded to three decimal places. ...
- ZOJ People Counting
第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ 3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...
- ZOJ 3686 A Simple Tree Problem
A Simple Tree Problem Time Limit: 3 Seconds Memory Limit: 65536 KB Given a rooted tree, each no ...
- ZOJ Problem Set - 1394 Polar Explorer
这道题目还是简单的,但是自己WA了好几次,总结下: 1.对输入的总结,加上上次ZOJ Problem Set - 1334 Basically Speaking ac代码及总结这道题目的总结 题目要求 ...
- ZOJ Problem Set - 1392 The Hardest Problem Ever
放了一个长长的暑假,可能是这辈子最后一个这么长的暑假了吧,呵呵...今天来实验室了,先找了zoj上面简单的题目练练手直接贴代码了,不解释,就是一道简单的密文转换问题: #include <std ...
- ZOJ Problem Set - 1049 I Think I Need a Houseboat
这道题目说白了是一道平面几何的数学问题,重在理解题目的意思: 题目说,弗雷德想买地盖房养老,但是土地每年会被密西西比河淹掉一部分,而且经调查是以半圆形的方式淹没的,每年淹没50平方英里,以初始水岸线为 ...
- ZOJ Problem Set - 1006 Do the Untwist
今天在ZOJ上做了道很简单的题目是关于加密解密问题的,此题的关键点就在于求余的逆运算: 比如假设都是正整数 A=(B-C)%D 则 B - C = D*n + A 其中 A < D 移项 B = ...
随机推荐
- web认证方案
web构建在http之上,而它又是无状态协议,如何控制用户访问服务器上的受限资源呢? 最原始你想法通过http基本认证,每次发请求时都向后台传递用户名密码信息,服务器每次收到请求后都先验证用户是否合法 ...
- bzoj 4198 [ Noi 2015 ] 荷马史诗 —— 哈夫曼编码(k叉哈夫曼树)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4198 第一次写哈夫曼树!看了很多博客. 哈夫曼树 & 哈夫曼编码:https://w ...
- 杂项:UML
ylbtech-杂项:UML Unified Modeling Language (UML)又称统一建模语言或标准建模语言,是始于1997年一个OMG标准,它是一个支持模型化和软件系统开发的图形化语言 ...
- nodejs windows环境安装
相信对于很多关注javascript发展的同学来说,nodejs已经不是一个陌生的词眼.有关nodejs的相关资料网上已经铺天盖地.由于它的高并发特性,造就了其特殊的应用地位. 国内目前关注最高,维护 ...
- 【BZOJ2693】jzptab & 【BZOJ2154】Crash的数字表格
题目 弱化版题目的传送门([BZOJ2154]Crash的数字表格) 加强版题目的传送门([BZOJ2693]jzptab) 思路&解法 题目是要求: \(\sum\limits_{i = 1 ...
- 「LOJ10150」括号配对
[题目] Hecy 又接了个新任务:BE 处理.BE 中有一类被称为 GBE. 以下是 GBE 的定义: 空表达式是 GBE 如果表达式 A 是 GBE,则 [A] 与 (A) 都是 GBE 如果 A ...
- bitmap实现背景透明
近日在项目中,一直被一个问题搞得头大的很,美工要把按钮图片弄成不规则的,但是在winform里实现又不仅仅是使用简单的png图片而已.在网上找到一些方法,稍微改了一点加工成项目所需. 贴出解决方案,以 ...
- shiro英语
Security Manager安全管理人员 Tutorial 辅导的 transient 短暂的 Cipher 密码 Memory 记忆 Access 访问Handy Hint 方便提示separa ...
- Asp.net MVC4 Step By Step(4)-使用Ajax
Ajax技术就是利用Javascript和XML技术实现这样的效果, 可以向Web服务器发送异步请求, 返回更新部分页面的数据, 而不需要全部更新整个页面. Ajax请求两种类型的内容, 一种是服务端 ...
- page事件
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu ...