博客
关于我
【旋转卡壳】poj 2187 Beauty Contest
阅读量:629 次
发布时间:2019-03-14

本文共 2185 字,大约阅读时间需要 7 分钟。

Link:

旋转卡壳(求平面最远对(O(N)))

先求出其凸包,找凸包所有边的与其他点最大三角形,其点即为边的最远点,
再计算边两端点的与边的最远点距离,取下最大距离。
当我们逆时针枚举边的时候,最远点的变化也是逆时针的,这样就可以不用从头计算最远点,
而可以紧接着上一次的最远点继续计算。于是我们得到了O(n)的算法。

#include 
#include
#include
using namespace std;/*poj 2187题意:给你一些点,找最远的两点题解:旋转卡壳*/const int N = 50010;const double PI = acos(-1.0);struct Point{ double x,y;};bool cmp(Point aa,Point bb){ if(aa.y != bb.y) return aa.y < bb.y; return aa.x < bb.x;} //是否严格左转,共线不算(叉乘) //计算三角形面积(叉乘)double xmult(Point a,Point b,Point c) //(ca)×(cb){ return (a.x-c.x)*(b.y-c.y)-(b.x-c.x)*(a.y-c.y);}Point a[N];int n,cnt,tail;int tmp[N],ans[N];void Graham(){ sort(a,a+n,cmp);// for(int i = 0; i < n; i++)// printf("%d %f %f\n",i,a[i].x,a[i].y); cnt = tail = 0; tmp[tail++] = 0; tmp[tail++] = 1; for(int i = 2; i < n; i++) { while(tail>1 && xmult(a[tmp[tail-1]],a[i],a[tmp[tail-2]])<=0) //是否严格左转 tail--; tmp[tail++] = i; } for(int i = 0; i < tail; i++) ans[cnt++] = tmp[i]; tail = 0; tmp[tail++] = n-1; tmp[tail++] = n-2; for(int i = n-3; i >= 0; i--) { while(tail>1 && xmult(a[tmp[tail-1]],a[i],a[tmp[tail-2]])<=0) //是否严格左转 tail--; tmp[tail++] = i; } cnt--; //去掉重复的点 for(int i = 0; i < tail; i++) ans[cnt++] = tmp[i];// for(int i = 0; i < cnt; i++)// printf("%d ",ans[i]);// puts("");}double dist(Point p1,Point p2){ return sqrt((p1.x-p2.x)*(p1.x-p2.x) + (p1.y-p2.y)*(p1.y-p2.y));}int dist2(Point p1,Point p2){ return (int)(p1.x-p2.x)*(p1.x-p2.x) + (int)(p1.y-p2.y)*(p1.y-p2.y);}int rotating_calipers() //旋转卡壳{ int q=1; //处理到的点 int res = 0; for(int i = 0; i < cnt-1; i++){ while(xmult(a[ans[q+1]],a[ans[i]],a[ans[i+1]]) > xmult(a[ans[q]],a[ans[i]],a[ans[i+1]])) //三角形面积 q = (q+1)%(cnt-1); res = max(res,max(dist2(a[ans[i]],a[ans[q]]),dist2(a[ans[i+1]],a[ans[q]])));// printf("%d %d %d\n",ans[i],ans[i+1],q); } return res;}int main(){ while(~scanf("%d",&n)) { for(int i = 0; i < n; i++) scanf("%lf%lf",&a[i].x,&a[i].y); Graham(); printf("%d\n",rotating_calipers()); } return 0;}

转载地址:http://wiaoz.baihongyu.com/

你可能感兴趣的文章
mysql的引擎以及优缺点_MySQL有哪些存储引擎,各自的优缺点,应用场景-阿里云开发者社区...
查看>>
MySQL的操作:
查看>>
mysql的数据类型有哪些?
查看>>
MYSQL的最左匹配原则的原理讲解
查看>>
mysql的语法规范
查看>>
MySql的连接查询
查看>>
mysql的配置文件参数
查看>>
MySQL的错误:No query specified
查看>>
mysql监控工具-PMM,让你更上一层楼(上)
查看>>
mysql监控工具-PMM,让你更上一层楼(下)
查看>>
MySQL相关命令
查看>>
mysql社工库搭建教程_社工库的搭建思路与代码实现
查看>>
Warning: Can't perform a React state update on an unmounted component. This is a no-
查看>>
mysql笔记 (早前的,很乱)
查看>>
MySQL笔记:InnoDB的锁机制
查看>>
mysql第一天~mysql基础【主要是DDL、DML、DQL语句,以及重点掌握存存引擎、查询(模糊查询)】
查看>>
mysql第二天~mysql基础【查询排序、分页查询、多表查询、数据备份与恢复等】
查看>>
MySQL简介和安装
查看>>
MySQL简单查询
查看>>
MySQL管理利器 MySQL Utilities 安装
查看>>