poj 1556 The door
题目链接: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的更多相关文章
- 最短路+线段交 POJ 1556 好题
// 最短路+线段交 POJ 1556 好题 // 题意:从(0,5)到(10,5)的最短距离,中间有n堵墙,每堵上有两扇门可以通过 // 思路:先存图.直接n^2来暴力,不好写.分成三部分,起点 终 ...
- POJ 1556 - The Doors 线段相交不含端点
POJ 1556 - The Doors题意: 在 10x10 的空间里有很多垂直的墙,不能穿墙,问你从(0,5) 到 (10,5)的最短距离是多少. 分析: 要么直达,要么 ...
- POJ 1556 The Doors 线段交 dijkstra
LINK 题意:在$10*10$的几何平面内,给出n条垂直x轴的线,且在线上开了两个口,起点为$(0, 5)$,终点为$(10, 5)$,问起点到终点不与其他线段相交的情况下的最小距离. 思路:将每个 ...
- poj 1556 (Dijkstra + Geometry 线段相交)
链接:http://poj.org/problem?id=1556 The Doors Time Limit: 1000MS Memory Limit: 10000K Total Submissi ...
- poj 1556 zoj1721 BellmanFord 最短路+推断直线相交
http://poj.org/problem?id=1556 The Doors Time Limit: 1000MS Memory Limit: 10000K Total Submissions ...
- POJ 1556 - The Doors - [平面几何+建图spfa最短路]
题目链接:http://poj.org/problem?id=1556 Time Limit: 1000MS Memory Limit: 10000K Description You are to f ...
- POJ 1556 The Doors【最短路+线段相交】
思路:暴力判断每个点连成的线段是否被墙挡住,构建图.求最短路. 思路很简单,但是实现比较复杂,模版一定要可靠. #include<stdio.h> #include<string.h ...
- 【POJ 1556】The Doors 判断线段相交+SPFA
黑书上的一道例题:如果走最短路则会碰到点,除非中间没有障碍. 这样把能一步走到的点两两连边,然后跑SPFA即可. #include<cmath> #include<cstdio> ...
- poj 1556 The Doors
The Doors Time Limit: 1000 MS Memory Limit: 10000 KB 64-bit integer IO format: %I64d , %I64u Java ...
随机推荐
- 实现多个ContentProvider对多张表进行操作
http://blog.csdn.net/maylian7700/article/details/7365373 SQLite数据库直接操作类: DatabaseHelper.java package ...
- Solaris用户管理(一):用户与组管理
Solaris用户管理(一):用户与组管理 2008-07-01 09:19 用户管理是系统管理的基础.Solaris中不但支持传统Unix所支持的用户和组的概念,还从Solaris 8开始引入了基 ...
- SQL Server Management Studio的对象资源管理器的使用
1.查看 2.对象资源管理器 3.点到某个表的身上 4.出现以下图片,因为有时动态创建的触发器,刷新表下面的触发器可能不出来,所以来这里面找
- 解决Undefined symbols for architecture x86_64: 报错 和 ld: warning: ld: warning: ignoring file警告
出现这种错误的情况: 用iphone5模拟器编译程序正常, 用iphone5s以上的模拟器编译出现Undefined symbols for architecture x86_64: 报错 和 ld: ...
- Spring配置多数据源错误总结
由于系统需要调用多个数据源包含mysql,sqlServe和Oracle,所以要在Spring的xml文件中配置多数据源,一下是配置过程中常见的错误: 1.配置的是mysql的数据源,却报oracle ...
- Tomcat设置最佳线程数总结
最佳线程数: 性能压测的情况下,起初随着用户数的增加,QPS会上升,当到了一定的阀值之后,用户数量增加QPS并不会增加,或者增加不明显,同时请求的响应时间却大幅增加.这个阀值我们认为是最佳线程数. 为 ...
- SGU 191.Exhibition(模拟)
时间限制:0.25s 空间限制:4M 题意: 有两个公司A.B,他们要展览物品,但是A公司的展柜要放B公司的物品,B公司的展柜要放A公司物品.最开始只有一个空柜台,从指定的一个公司开始,轮流进行操作, ...
- 第二篇、Maven快速上手
1.目标 该篇主要是为了快速利用maven来构建工程,maven作为项目管理的工具已经得到极大程度的应用,很多开源项目都用maven来构建.如何建立 一个maven工程,如何导入别人的maven工程, ...
- Vim及VimScript资料总结《转载》
版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] Vim教程 入门 Vim 实用技术 Learning the vi and Vim Editors A Byte of ...
- 简单工厂模式的C++实现
用简单工厂模式实现一个计算器类: #include <iostream> #include <string> using namespace std; class Operat ...