题目链接:http://poj.org/problem?id=1556

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
const int maxn = ;
const int maxe = ;
const int INF = 0x3f3f3f;
const double eps = 1e-;
const double PI = acos(-1.0); struct Point{
double x,y;
Point(double x=, double y=) : x(x),y(y){ } //构造函数
};
typedef Point Vector; Vector operator + (Vector A , Vector B){return Vector(A.x+B.x,A.y+B.y);}
Vector operator - (Vector A , Vector B){return Vector(A.x-B.x,A.y-B.y);}
Vector operator * (Vector A , double p){return Vector(A.x*p,A.y*p);}
Vector operator / (Vector A , double p){return Vector(A.x/p,A.y/p);} bool operator < (const Point& a,const Point& b){
return a.x < b.x ||( a.x == b.x && a.y < b.y);
} int dcmp(double x){
if(fabs(x) < eps) return ;
else return x < ? - : ;
}
bool operator == (const Point& a, const Point& b){
return dcmp(a.x - b.x) == && dcmp(a.y - b.y) == ;
} ///向量(x,y)的极角用atan2(y,x);
double Dot(Vector A, Vector B){ return A.x*B.x + A.y*B.y; }
double Length(Vector A) { return sqrt(Dot(A,A)); }
double Angle(Vector A, Vector B) { return acos(Dot(A,B) / Length(A) / Length(B)); } double Cross(Vector A, Vector B) { return A.x*B.y - A.y * B.x; }
double Area2(Point A,Point B,Point C) { return Cross(B-A,C-A); } bool SegmentIntersection(Point a1, Point a2, Point b1, Point b2) {
bool flag = max(a1.x, a2.x) >= min(b1.x, b2.x) && max(b1.x, b2.x) >= min(a1.x, a2.x) &&
max(a1.y, a2.y) >= min(b1.y, b2.y) && max(b1.y, b2.y) >= min(a1.y, a2.y);
double c1 = Cross(a2-a1,b1-a1), c2 = Cross(a2-a1,b2-a1),
c3 = Cross(b2-b1,a1-b1), c4 = Cross(b2-b1,a2-b1);
return flag && dcmp(c1) * dcmp(c2) < && dcmp(c3) * dcmp(c4) < ;
} bool SegmentProperIntersection(Point a1,Point a2,Point b1,Point b2){
double c1 = Cross(a2-a1,b1-a1), c2 = Cross(a2-a1,b2-a1),
c3 = Cross(b2-b1,a1-b1), c4 = Cross(b2-b1,a2-b1);
return dcmp(c1) * dcmp(c2) < && dcmp(c3) * dcmp(c4) < ;
} struct Edge{
int u,v;
double w;
int next;
void assign(int u_,int v_,double w_,int next_){
u = u_; v = v_; w = w_; next = next_;
}
bool operator < (const Edge& r) const{
return w > r.w;
}
}edges[maxe]; struct Dijkstra{
int s,t;
int head[maxn];
int cnt;
double d[maxn]; void addedge(int u,int v,double w){
edges[cnt].assign(u,v,w,head[u]);
head[u] = cnt++;
} void init(int s_,int t_){
s = s_; t = t_;
cnt = ;
memset(head,-,sizeof(head));
} double dijkstra(){
priority_queue<Edge> Q;
while(!Q.empty()) Q.pop();
for(int i=;i<=maxn;i++) d[i] = INF;
bool vis[maxn];
memset(vis,,sizeof(vis));
Edge edge = {s,,};
Q.push(edge); d[s] = ;
while(!Q.empty()){
Edge e = Q.top() ; Q.pop() ;
int u = e.u;
if(vis[u]) continue;
vis[u] = true;
for(int i=head[u];i!=-;i=edges[i].next){
int v = edges[i].v;
if( d[v] > d[u] + edges[i].w){
d[v] = d[u] + edges[i].w;
Edge edge = {v,,d[v]};
Q.push(edge);
}
}
}
return d[t];
}
}; /************************分割线****************************/ Point P[maxn][];
int n;
Dijkstra solver;
int main()
{
//freopen("E:\\acm\\input.txt","r",stdin); while(cin>>n && n != -){
solver.init(,*n+);
P[][] =Point(,); P[n+][] =Point(,);
for(int i=;i<=n;i++){
double x,y;
scanf("%lf",&x);
for(int j=;j<=;j++){
scanf("%lf",&y);
P[i][j]=Point(x,y);
}
} for(int i=;i<=n;i++){
if(i==){
for(int j=i+;j<=n;j++)
for(int k=;k<=;k++){
int flag = true;
for(int m=;m<=j-;m++){
Point a1=P[m][],a2=P[m][],b1=P[m][],b2=P[m][];
if(!SegmentIntersection(P[][],P[j][k],a1,a2) && !SegmentIntersection(P[][],P[j][k],b1,b2)){
flag = false; break;
}
}
if(flag){
solver.addedge(,*j+k-,Length(P[][]-P[j][k]));
}
}
int flag = true;
for(int m=;m<=n;m++){
Point a1=P[m][],a2=P[m][],b1=P[m][],b2=P[m][];
if(!SegmentIntersection(P[][],P[n+][],a1,a2) && !SegmentIntersection(P[][],P[n+][],b1,b2)){
flag = false; break;
}
}
if(flag){
solver.addedge(,*n+,Length(P[][]-P[n+][]));
} }
else{
for(int h=;h<=;h++){ //确定点P[i][h]
for(int j=i+;j<=n;j++)
for(int k=;k<=;k++){ //确定点p[j][k];
int flag = true;
for(int m=i+;m<=j-;m++){
Point a1=P[m][],a2=P[m][],b1=P[m][],b2=P[m][];
if(!SegmentIntersection(P[i][h],P[j][k],a1,a2)&&!SegmentIntersection(P[i][h],P[j][k],b1,b2)){
flag = false; break;
}
}
if(flag){
solver.addedge(*i+h-,*j+k-,Length(P[i][h]-P[j][k]));
}
}
int flag = true;
for(int m=i+;m<=n;m++){
Point a1=P[m][],a2=P[m][],b1=P[m][],b2=P[m][];
if(!SegmentIntersection(P[i][h],P[n+][],a1,a2)&&!SegmentIntersection(P[i][h],P[n+][],b1,b2)){
flag = false; break;
}
}
if(flag){
solver.addedge(*i+h-,*n+,Length(P[i][h]-P[n+][]));
}
}
}
}
printf("%.2f\n",solver.dijkstra());
}
}

poj 1556 The door的更多相关文章

  1. 最短路+线段交 POJ 1556 好题

    // 最短路+线段交 POJ 1556 好题 // 题意:从(0,5)到(10,5)的最短距离,中间有n堵墙,每堵上有两扇门可以通过 // 思路:先存图.直接n^2来暴力,不好写.分成三部分,起点 终 ...

  2. POJ 1556 - The Doors 线段相交不含端点

    POJ 1556 - The Doors题意:    在 10x10 的空间里有很多垂直的墙,不能穿墙,问你从(0,5) 到 (10,5)的最短距离是多少.    分析:        要么直达,要么 ...

  3. POJ 1556 The Doors 线段交 dijkstra

    LINK 题意:在$10*10$的几何平面内,给出n条垂直x轴的线,且在线上开了两个口,起点为$(0, 5)$,终点为$(10, 5)$,问起点到终点不与其他线段相交的情况下的最小距离. 思路:将每个 ...

  4. poj 1556 (Dijkstra + Geometry 线段相交)

    链接:http://poj.org/problem?id=1556 The Doors Time Limit: 1000MS   Memory Limit: 10000K Total Submissi ...

  5. poj 1556 zoj1721 BellmanFord 最短路+推断直线相交

    http://poj.org/problem?id=1556 The Doors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions ...

  6. POJ 1556 - The Doors - [平面几何+建图spfa最短路]

    题目链接:http://poj.org/problem?id=1556 Time Limit: 1000MS Memory Limit: 10000K Description You are to f ...

  7. POJ 1556 The Doors【最短路+线段相交】

    思路:暴力判断每个点连成的线段是否被墙挡住,构建图.求最短路. 思路很简单,但是实现比较复杂,模版一定要可靠. #include<stdio.h> #include<string.h ...

  8. 【POJ 1556】The Doors 判断线段相交+SPFA

    黑书上的一道例题:如果走最短路则会碰到点,除非中间没有障碍. 这样把能一步走到的点两两连边,然后跑SPFA即可. #include<cmath> #include<cstdio> ...

  9. poj 1556 The Doors

    The Doors Time Limit: 1000 MS Memory Limit: 10000 KB 64-bit integer IO format: %I64d , %I64u   Java ...

随机推荐

  1. java可变参数Varargs

    http://www.cnblogs.com/shishm/archive/2012/01/31/2332656.html J2SE 1.5提供了“Varargs”机制.借助这一机制,可以定义能和多个 ...

  2. ASP.NET和支付宝合作开发第三方接口的注意事项

    最近公司和支付宝合作开发第三方接口的项目,这里把过程中需要注意的地方说明一下: 前提:一般来说单个银行不接收个人或私企开通支付接口.因此,和第三方支付公司合作,签订合约开放接口就是通行的做法. 流程: ...

  3. windows sever 2008 r2 - 限制ip访问

    和win 7 旗舰版不同,该操作系统在安装IIS后,非本机的并不能直接访问主机.需要设置主机上的本机的IIS中的IP地址和域限制. 由于我是想在同一个局域网(路由器)中,通过Android操作系统访问 ...

  4. 【转】 iOS-Core-Animation-Advanced-Techniques(七)

    高效绘图.图像IO以及图层性能 高效绘图 原文:http://www.cocoachina.com/ios/20150106/10840.html 不必要的效率考虑往往是性能问题的万恶之源. ——Wi ...

  5. Windows 8 / 8.1 禁用驱动签名最详细图文教程

    Windows 8 鼠标右上角/右下角弹出边栏,选择“设置” 点击“更改电脑设置”: 选择“常规”,右侧拖到底,点击“高级启动”-“立即重启”: 稍后进入恢复页面,选择“疑难解答” 进入疑难解答后,选 ...

  6. 371. Sum of Two Integers -- Avota

    问题描述: Calculate the sum of two integers a and b, but you are not allowed to use the operator + and - ...

  7. gdb小结

    testGdb.c #include<stdio.h> int getSum(int a,int b){ printf("a+b=%d\n",a+b); return ...

  8. 页面点击关闭弹出提示js代码

    代码效果为: <script> window.onbeforeunload = function() { return "您好!\n我是abc\n —————————————— ...

  9. thinkphp微信开发之jssdk图片上传并下载到本地服务器

    public function test2(){ $Weixin = new \Weixin\Controller\BaseController(); $this->assign('signPa ...

  10. DEDECMS栏目自定义字段添加

    用到的文件: catalog_add.htm  路径:\dede\templets\ catalog_edit.htm  路径:\dede\templets\  catalog_add.php  路径 ...