题目链接 POJ-3608 Bridge Across Islands

题意

依次按逆时针方向给出凸包,在两个凸包小岛之间造桥,求最小距离。

题解

旋转卡壳的应用之一:求两凸包的最近距离。



找到凸包 p 的 y 值最小点 yminP 和 q 的 y 值最大点ymaxQ,然后分别做切线如图。

那么\(AC\times AD> AC\times AB\)则说明B还不是离AC最近的点,所以++ymaxQ。

否则用 \(AC\) 和 \(BD\) 两个线段的距离更新最近距离,并且++yminP,即考察P的下一条边。

代码

#include <cstdio>
#include <cmath>
#include <algorithm>
#define sqr(x) (x)*(x)
#define N 50001
#define EPS (1e-8)
#define PI acos(-1.0)
#define INF (1e99)
using namespace std;
int sgn(double x) {
if(fabs(x) < EPS)return 0;
return (x < 0)?-1:1;
}
struct Point {
double x,y;
Point(double _x=0,double _y=0):x(_x), y(_y){}
Point operator -(const Point &b)const {
return Point(x - b.x,y - b.y);
}
Point operator +(const Point &b)const {
return Point(x + b.x,y + b.y);
}
double operator ^(const Point &b)const {
return x*b.y - y*b.x;
}
double operator *(const Point &b)const {
return x*b.x + y*b.y;
}
void in(){
scanf("%lf%lf",&x,&y);
}
};
double dis2(Point a,Point b){
return sqr(a-b);
}
double dist(Point a,Point b){
return sqrt(dis2(a,b));
}
struct Line {
Point s,e;
Line(){}
Line(Point _s,Point _e):s(_s),e(_e) {}
};
double xmult(Point a,Point b,Point o){
return (a-o)^(b-o);
}
double mult(Point a, Point b, Point o){
return (a-o)*(b-o);
}
double disToSeg(Point P,Line L){
if(!sgn(dis2(L.s,L.e)))
return dist(L.s,P);
if(sgn(mult(P,L.e,L.s))<0)return dist(L.s,P);
if(sgn(mult(P,L.s,L.e))<0)return dist(L.e,P);
return fabs(xmult(P,L.s,L.e))/dist(L.s,L.e);
}
double segToSeg(Line l1,Line l2){
return min(min(disToSeg(l1.s,l2),disToSeg(l1.e,l2)),min(disToSeg(l2.s,l1),disToSeg(l2.e,l1)));
}
Point p[N],q[N];
int n,m;
double qiake(){
int yminp=0,ymaxq=0;
for(int i=1;i<n;++i)
if(p[i].y<p[yminp].y)
yminp=i;
for(int i=1;i<m;++i)
if(q[i].y>q[ymaxq].y)
ymaxq=i;
p[n]=p[0];
q[m]=q[0];
double tmp,ans=INF;
for(int i=0;i<n;++i){
while(tmp=sgn(xmult(p[yminp+1],q[ymaxq+1],p[yminp])
-xmult(p[yminp+1],q[ymaxq],p[yminp]))>0)
ymaxq=(ymaxq+1)%m;
ans=min(ans,segToSeg(Line(p[yminp],p[yminp+1]),Line(q[ymaxq],q[ymaxq+1])));
yminp=(yminp+1)%n;
}
return ans;
}
int main(){
while(~scanf("%d%d",&n,&m)&&n&&m){
for(int i=0;i<n;++i)
p[i].in();
for(int i=0;i<m;++i)
q[i].in();
printf("%f\n",qiake());
}
return 0;
}

「POJ-3608」Bridge Across Islands (旋转卡壳--求两凸包距离)的更多相关文章

  1. POJ3608(旋转卡壳--求两凸包的最近点对距离)

    题目:Bridge Across Islands 分析:以下内容来自:http://blog.csdn.net/acmaker/article/details/3178696 考虑如下的算法, 算法的 ...

  2. POJ 3608 Bridge Across Islands(旋转卡壳,两凸包最短距离)

    Bridge Across Islands Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7202   Accepted:  ...

  3. POJ 3608 Bridge Across Islands [旋转卡壳]

    Bridge Across Islands Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10455   Accepted: ...

  4. poj 3608 旋转卡壳求不相交凸包最近距离;

    题目链接:http://poj.org/problem?id=3608 #include<cstdio> #include<cstring> #include<cmath ...

  5. poj 3608(旋转卡壳求解两凸包之间的最短距离)

    Bridge Across Islands Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9768   Accepted: ...

  6. 旋转卡壳求两个凸包最近距离poj3608

    #include <iostream> #include <cmath> #include <vector> #include <string.h> # ...

  7. POJ2187 旋转卡壳 求最长直径

    给定平面上的一些散点集,求最远两点距离的平方值. 题解: 旋转卡壳求出凸包,然后根据单调性,求出最远两点的最大距离 #pragma GCC optimize(2) #pragma G++ optimi ...

  8. 「POJ 3666」Making the Grade 题解(两种做法)

    0前言 感谢yxy童鞋的dp及暴力做法! 1 算法标签 优先队列.dp动态规划+滚动数组优化 2 题目难度 提高/提高+ CF rating:2300 3 题面 「POJ 3666」Making th ...

  9. POJ 2187 Beauty Contest【旋转卡壳求凸包直径】

    链接: http://poj.org/problem?id=2187 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22013#probl ...

随机推荐

  1. codeforces#580 D. Kefa and Dishes(状压dp)

    题意:有n个菜,每个菜有个兴奋值,并且如果吃饭第i个菜立即吃第j个菜,那么兴奋值加ma[i][j],求吃m个菜的最大兴奋值,(n<=18) 分析:定义dp[status][last],statu ...

  2. DWZ富客户端框架(jQuery RIA framework)

    该OA项目前端采用的是DWZ框架来进行实现的. 本来想写点总结的,但发现真没啥好写的.中文的文档,到时候用到直接看文档就好.

  3. UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-25: ordinal not in range(128)

    python报错:UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-25: ordinal not in ...

  4. mysql cpu 100% 满 优化方案

    解决MySQL CPU占用100%的经验总结 - karl_han的专栏 - CSDN博客 https://blog.csdn.net/karl_han/article/details/5630782 ...

  5. Laravel自带SMTP邮件组件实现发送邮件(QQ、163、企业邮箱都可)

    Laravel自带SMTP邮件组件实现发送邮件(QQ.163.企业邮箱都可)     laravel自带SMTP邮件配置和遇到的坑 laravel自带SwiftMailer库,集成了多种邮件API,可 ...

  6. bnu——GCD SUM (莫比乌斯反演)

    题目:GCD SUM 题目链接:http://www.bnuoj.com/v3/problem_show.php?pid=39872 算法:莫比乌斯反演.优化 #include<stdio.h& ...

  7. .Net中EF通用数据层小结

    增删改查: using System; using System.Collections.Generic; using System.Data; using System.Data.Entity; u ...

  8. VUE 处理文本框获焦点高亮

    先贴例子代码  这里又三个div对应的三个input输入框 <!-- 登录的表单 --> <div class="input_group" :class=&quo ...

  9. scala下划线

    作为函数的参数 一个匿名的函数传递给一个方法或者函数的时候,scala会尽量推断出参数类型.例如一个完整的匿名函数作为参数可以写为 scala> def compute(f: (Double)= ...

  10. python学习笔记(11)--文件与数据格式化

    文件的概念: 文件是数据的抽象和集合,是存储在辅助存储器上的数据序列,文件是数据存储的一种形式,文件的展现形态,文本文件和二进制文件. 文本文件输出: f.txt文件保存:“我是中国人” >&g ...