凸包(极角序)模板
2016-02-16 11:01
274 查看
#include<cstdio> #include<iostream> #include<cmath> #define INF 1000000000 using namespace std; struct Point{ double x,y; }p[100005],st[100005]; int n,top; double multiply(Point sp,Point ep,Point op){ return (sp.x-op.x)*(ep.y-op.y)-(ep.x-op.x)*(sp.y-op.y); } double dist(Point sp,Point op){ return sqrt((sp.x-op.x)*(sp.x-op.x)+(sp.y-op.y)*(sp.y-op.y)); } bool cmp(const Point &a,const Point &b){ double tmp=multiply(a,b,p[0]); return !(tmp<0||tmp==0&&dist(a,p[0])>dist(b,p[0])); } int main(){ freopen("convex.in","r",stdin); freopen("convex.out","w",stdout); cin>>n; int i,mini; double minx=INF,miny=INF; for(i=1;i<=n;i++){ scanf("%lf %lf",&p[i].x,&p[i].y); if(p[i].y<miny||p[i].y==miny&&p[i].x<minx){ minx=p[i].x; miny=p[i].y; mini=i; } } p[0]=p[mini]; p[mini]=p[n--]; sort(p+1,p+n+1,cmp);/* for(i=0;i<=n;i++) printf("%.2lf %.2lf\n",p[i].x,p[i].y);*/ st[1]=p[0]; st[2]=p[1]; top=2; for(i=2;i<=n;i++){ double tmp=multiply(st[top],p[i],st[top-1]); while(tmp<=0&&top>=2){ top--; if(top>=2)tmp=multiply(st[top],p[i],st[top-1]); } st[++top]=p[i]; } for(i=1;i<=top;i++) printf("%.0lf %.0lf\n",st[i].x,st[i].y); return 0; }
相关文章推荐
- Git的使用教程(六)管理修改
- jQuery EasyUI使用教程之自定义数据网格分页
- 中间人攻击 -- Cookie喷发
- ListView实下拉刷新的大概思路
- jdbc编程步骤
- ajaxpro——js调用后台的方法
- RCP CommonNavigator导航视图问题
- Redis常用命令
- 证明:任意整数与其倒序数的差能被9整除
- 【bzoj1433】[ZJOI2009]假期的宿舍 二分图匹配
- CocoaPod代码库创建,配置Spec踩过的坑
- 【Oracle】曾经的Oracle学习笔记(8-15)ER图,三大范式,数据库字典,视图,索引,序列
- 新起点,新征程
- 为什么字符串会有length属性-JS中包装对象
- PHP模拟post提交数据方法汇总
- java 权限修饰符
- VMware安装centos
- Linux下Maven的安装与使用
- 【Oracle】曾经的Oracle学习笔记(4-7)多表联合查询,子查询,动态条件查询
- 浅谈压缩感知(三十):压缩感知重构算法之L1最小二乘