题目链接: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. The windows PowerShell snap-in 'Microsoft.Crm.PowerShell' is not installed on this computer

    加载PowerShell插件时出现以下错误: The windows PowerShell snap-in 'Microsoft.Crm.PowerShell' is not installed on ...

  2. Unity Manual 用户手册

    unity3d 文档的中文网址:   http://game.ceeger.com/Manual/

  3. 对UIImage进行的一些操作

    1.生成指定宽高的UIImage对象(oldImage为原始图片对象,newImage为操作后的图片对象) // 参数1:图片的尺寸 参数2:是否透明(没看出YES和NO有什么区别) 参数3:缩放(1 ...

  4. 用html/css做的一个登入小界面(图片瀑布流)

    一个登入效果简易图:(色彩搭配有点乱,嘻嘻,可以在代码处改成自己喜欢的颜色) css样式的代码: style.css: @charset "utf-8";/* CSS Docume ...

  5. zTree异步生成数据时无法获取到子节点的选中状态

    最近在项目中遇到一个问题,需求如下: 根据选中不同的人员(ID)向后台发送ajax请求,通过返回的数据来生成该人员的权限访问树,该树目录最少为3级目录,在生成的时候会自动勾选上次保存过的选中状态,点击 ...

  6. mysql数据类型——枚举enum(‘F’,'M')

    ENUM(“value1”,“value2”,...) 说明:枚举,列值可赋予值列表中的某个成员 允许的属性:除通用属性外无其他属性 缺省值:如果列可为NULL,则为NULL:如果列为NOTNULL, ...

  7. CMD下查询Mysql中文乱码的解决方法

    我的MySQL是默认utf8编码的,所建数据库也是设置utf8编码,使用程序可以新增中文数据,在cmd中使用SQL语句新增数据则报类似Incorrect string value: '\xB2\xE2 ...

  8. PHP面向对象(OOP):__call()处理调用错误

    在程序开发中,如果在使用对象调用对象内部方法时候,调用的这个方法不存在那么程序就会出错,然后程序退出不能继续执行.那么可不可以在程序调用对象内部 不存在的方法时,提示我们调用的方法及使用的参数不存在, ...

  9. python【第九篇】多线程、多进程

    内容提要 paramiko模块 进程.与线程区别 python GIL全局解释器锁 多线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生 ...

  10. 在MAC下 Python+Django+mysql配置

    今天在搭建Django+mysql环境的时候遇到了一点问题,记录下来. 安装环境:OS X 10.10操作系统,Python 2.7. MySQLdb其实包含在MySQL-python包中,因此无论下 ...