模板,凸包

int TuBao(P p[],int n,P q[]){
    int m = 0;
    sort(p,p+n);
    for(int i=0;i<n;++i) {
        while (m>1 && dcmp(cross(q[m-2],q[m-1],p[i]))<=0) m--;
        q[m++] = p[i];
    }
    int k = m;
    for(int i=n-2;i>=0;--i){
        while(m>k && dcmp(cross(q[m-2],q[m-1],p[i]))<=0) m--;
        q[m++] = p[i];
    }
    for(int i=0;i<m;++i) p[i] = q[i];
    if(n>1)m--;
    return m;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章