首页 > 代码库 > USACO 5.1.1凸包
USACO 5.1.1凸包
转自:http://blog.csdn.net/cnyali/article/details/50097593
程序:
#include <iostream> #include <algorithm> #include <cstdio> #include <cmath> using namespace std; typedef struct { double x,y; }P; typedef struct { int s,t; double k,l; }E; int n,top; double sum; P p[10010]; E e[20020]; bool comp(const P &a,const P &b) { return a.x<b.x; } double dist(int a,int b) { return sqrt((p[a].x-p[b].x)*(p[a].x-p[b].x)+(p[a].y-p[b].y)*(p[a].y-p[b].y)); } double slope(int a,int b) { if (p[b].x-p[a].x==0) return 0; return (p[b].y-p[a].y)*1.0/(p[b].x-p[a].x); } int main() { freopen("fc.in","r",stdin); freopen("fc.out","w",stdout); int i,j; scanf("%d",&n); for (i=1;i<=n;i++) scanf("%lf%lf",&p[i].x,&p[i].y); sort (p+1,p+n+1,comp); i=1; while (i<n) { j=i+1; e[++top].s=i; e[top].t=j; e[top].l=dist(i,j); e[top].k=slope(i,j); while (top>1&&e[top-1].k>e[top].k) { top--; e[top].t=e[top+1].t; e[top].l=dist(e[top].s,e[top].t); e[top].k=slope(e[top].s,e[top].t); } i++; } while (top>0) sum+=e[top--].l; i=1; while (i<n) { j=i+1; e[++top].s=i; e[top].t=j; e[top].l=dist(i,j); e[top].k=slope(i,j); while (top>1&&e[top-1].k<e[top].k) { top--; e[top].t=e[top+1].t; e[top].l=dist(e[top].s,e[top].t); e[top].k=slope(e[top].s,e[top].t); } i++; } while (top>0) sum+=e[top--].l; printf("%.2f\n",sum); return 0; }
USACO 5.1.1凸包
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。