zoukankan      html  css  js  c++  java
  • Poj 2187 凸包模板求解

    Poj 2187 凸包模板求解

    传送门
    由于整个点数是50000,而求凸包后的点也不会很多,因此直接套凸包之后两重循环即可求解

    #include <queue>
    #include <cmath>
    #include <cstdio>
    #include <cstring>
    #include <cstdlib>
    #include <iostream>
    #include <algorithm>
    #define ll long long
    #define inf 1000000000LL
    #define mod 1000000007
    using namespace std;
    int read()
    {
        int x=0,f=1;
        char ch=getchar();
        while(ch<'0'||ch>'9')
        {
            if(ch=='-')f=-1;
            ch=getchar();
        }
        while(ch>='0'&&ch<='9')
        {
            x=x*10+ch-'0';
            ch=getchar();
        }
        return x*f;
    }
    const int N = 5e4+10;
    const double PI = acos(-1.0);
    const double eps = 1e-12;
    
    int dcmp(double x) {
        if(fabs(x)<eps) return 0; else return x<0? -1:1;
    }
    
    struct Pt {
        double x,y;
        Pt(double x=0,double y=0) :x(x),y(y) {};
    };
    typedef Pt vec;
    
    vec operator - (Pt a,Pt b) { return vec(a.x-b.x,a.y-b.y); }
    vec operator + (vec a,vec b) { return vec(a.x+b.x,a.y+b.y); }
    bool operator == (Pt a,Pt b) {
        return dcmp(a.x-b.x)==0 && dcmp(a.y-b.y)==0;
    }
    bool operator < (const Pt& a,const Pt& b) {
        return a.x<b.x || (a.x==b.x && a.y<b.y);
    }
    
    vec rotate(vec a,double x) {
        return vec(a.x*cos(x)-a.y*sin(x),a.x*sin(x)+a.y*cos(x));
    }
    double cross(vec a,vec b) { return a.x*b.y-a.y*b.x; }
    double dist(Pt a,Pt b) {
        //return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
        return ((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
    }
    
    vector<Pt> ConvexHull(vector<Pt> p) {
        sort(p.begin(),p.end());
        p.erase(unique(p.begin(),p.end()),p.end());
        int n=p.size() , m=0;
        vector<Pt> ch(n+1);
        for(int i=0;i<n;i++) {
            while(m>1 && cross(ch[m-1]-ch[m-2],p[i]-ch[m-2])<=0) m--;
            ch[m++]=p[i];
        }
        int k=m;
        for(int i=n-2;i>=0;i--) {
            while(m>k && cross(ch[m-1]-ch[m-2],p[i]-ch[m-2])<=0) m--;
            ch[m++]=p[i];
        }
        if(n>1) m--;
        ch.resize(m); return ch;
    }
    vector<Pt>q,con;
    int main(){
         int n=read();
         int x,y;
         for(int i=0;i<n;i++){
               x=read();y=read();
               q.push_back(Pt((double)x,(double)y));
         }
         con=ConvexHull(q);
         double ans=0;
         for(int i=0;i<con.size();i++){
            for(int j=i+1;j<con.size();j++){
                ans=max(ans,dist(con[i],con[j]));
            }
         }
         printf("%.0f
    ",ans);
         return 0;
    }
    
    
  • 相关阅读:
    PYTHON核心编程第7章 7.5题
    openssl大漏洞
    运维之路
    组件嵌套+Mixin函数demo
    React初识(按钮点击+输入绑定)
    vue切换按钮(关闭消失型)
    动态发表之后的显示时间
    展开全部的实现
    前端进行后台数据的处理
    将项目上传到git上,并在测试服务器上运行
  • 原文地址:https://www.cnblogs.com/zsyacm666666/p/6797818.html
Copyright © 2011-2022 走看看