这题是二分+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的更多相关文章

  1. zoj 3717 - Balloon(2-SAT)

    裸的2-SAT,详见刘汝佳训练指南P-323 不过此题有个特别需要注意的地方:You should promise that there is still no overlap for any two ...

  2. ZOJ 3717 Balloon ( TLE )

    正解2-SAT. 我用DLX想搜一搜的,结果TLE了…… 没什么遗憾,最起码我尝试过了. 扔个代码留作纪念. #include <cstdio> #include <cstring& ...

  3. ZOJ 3717 二分+2-sat判定。

    好久没有2-sat了,此题当复习之用,二分求最大值+2-sat判断可行,此题主要跪于题意:The results should be rounded to three decimal places. ...

  4. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  5. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

  6. ZOJ Problem Set - 1394 Polar Explorer

    这道题目还是简单的,但是自己WA了好几次,总结下: 1.对输入的总结,加上上次ZOJ Problem Set - 1334 Basically Speaking ac代码及总结这道题目的总结 题目要求 ...

  7. ZOJ Problem Set - 1392 The Hardest Problem Ever

    放了一个长长的暑假,可能是这辈子最后一个这么长的暑假了吧,呵呵...今天来实验室了,先找了zoj上面简单的题目练练手直接贴代码了,不解释,就是一道简单的密文转换问题: #include <std ...

  8. ZOJ Problem Set - 1049 I Think I Need a Houseboat

    这道题目说白了是一道平面几何的数学问题,重在理解题目的意思: 题目说,弗雷德想买地盖房养老,但是土地每年会被密西西比河淹掉一部分,而且经调查是以半圆形的方式淹没的,每年淹没50平方英里,以初始水岸线为 ...

  9. ZOJ Problem Set - 1006 Do the Untwist

    今天在ZOJ上做了道很简单的题目是关于加密解密问题的,此题的关键点就在于求余的逆运算: 比如假设都是正整数 A=(B-C)%D 则 B - C = D*n + A 其中 A < D 移项 B = ...

随机推荐

  1. web认证方案

    web构建在http之上,而它又是无状态协议,如何控制用户访问服务器上的受限资源呢? 最原始你想法通过http基本认证,每次发请求时都向后台传递用户名密码信息,服务器每次收到请求后都先验证用户是否合法 ...

  2. bzoj 4198 [ Noi 2015 ] 荷马史诗 —— 哈夫曼编码(k叉哈夫曼树)

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4198 第一次写哈夫曼树!看了很多博客. 哈夫曼树 & 哈夫曼编码:https://w ...

  3. 杂项:UML

    ylbtech-杂项:UML Unified Modeling Language (UML)又称统一建模语言或标准建模语言,是始于1997年一个OMG标准,它是一个支持模型化和软件系统开发的图形化语言 ...

  4. nodejs windows环境安装

    相信对于很多关注javascript发展的同学来说,nodejs已经不是一个陌生的词眼.有关nodejs的相关资料网上已经铺天盖地.由于它的高并发特性,造就了其特殊的应用地位. 国内目前关注最高,维护 ...

  5. 【BZOJ2693】jzptab & 【BZOJ2154】Crash的数字表格

    题目 弱化版题目的传送门([BZOJ2154]Crash的数字表格) 加强版题目的传送门([BZOJ2693]jzptab) 思路&解法 题目是要求: \(\sum\limits_{i = 1 ...

  6. 「LOJ10150」括号配对

    [题目] Hecy 又接了个新任务:BE 处理.BE 中有一类被称为 GBE. 以下是 GBE 的定义: 空表达式是 GBE 如果表达式 A 是 GBE,则 [A] 与 (A) 都是 GBE 如果 A ...

  7. bitmap实现背景透明

    近日在项目中,一直被一个问题搞得头大的很,美工要把按钮图片弄成不规则的,但是在winform里实现又不仅仅是使用简单的png图片而已.在网上找到一些方法,稍微改了一点加工成项目所需. 贴出解决方案,以 ...

  8. shiro英语

    Security Manager安全管理人员 Tutorial 辅导的 transient 短暂的 Cipher 密码 Memory 记忆 Access 访问Handy Hint 方便提示separa ...

  9. Asp.net MVC4 Step By Step(4)-使用Ajax

    Ajax技术就是利用Javascript和XML技术实现这样的效果, 可以向Web服务器发送异步请求, 返回更新部分页面的数据, 而不需要全部更新整个页面. Ajax请求两种类型的内容, 一种是服务端 ...

  10. page事件

    using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu ...