zoukankan      html  css  js  c++  java
  • POJ2187 旋转卡壳+凸包

    题意:给定一些点,求最远的点的距离。

    凸包+旋转卡壳

    View Code
      1 /*
      2 旋转卡壳
      3 凸包中的点为顺时针存储
      4 */
      5 #include<stdio.h>
      6 #include<string.h>
      7 #include<stdlib.h>
      8 #include<algorithm>
      9 #include<iostream>
     10 #include<queue>
     11 //#include<map>
     12 #include<math.h>
     13 using namespace std;
     14 typedef long long ll;
     15 //typedef __int64 int64;
     16 const int maxn = 50005;
     17 const int inf = 0x7fffffff;
     18 struct node{
     19     int x,y;
     20     bool operator <( const node &p ) const {
     21         return y<p.y||(y==p.y&&x<p.x);
     22     }
     23 };
     24 node pnt[ maxn ],res[ maxn ];
     25 int cross( node sp,node ep,node op ){
     26      return (sp.x - op.x) * (ep.y - op.y)-(ep.x - op.x) * (sp.y - op.y);
     27 }
     28 /*
     29 ep
     30 |
     31 |
     32 op----sp
     33 ( from sp to ep )
     34 */
     35 
     36 int dis2( node a,node b ){
     37     return (( a.x-b.x )*( a.x-b.x )+( a.y-b.y )*( a.y-b.y ));
     38 }
     39 
     40 int graham( int n ){
     41     int top=1;
     42     sort( pnt,pnt+n );//!!!!!
     43     if( n==0 ) return 0;
     44     else res[ 0 ]=pnt[ 0 ];
     45     if( n==1 ) return 1;
     46     else res[ 1 ]=pnt[ 1 ];
     47     if( n==2 ) return 2;
     48     else res[ 2 ]=pnt[ 2 ];
     49     
     50     for( int i=2;i<n;i++ ){
     51         while( top>0&&cross( res[ top ],pnt[ i ],res[ top-1 ] )>=0 )
     52             top--;
     53         res[ ++top ]=pnt[ i ];
     54     }
     55     int tmp=top;
     56     res[ ++top ]=pnt[ n-2 ];
     57     for( int i=n-3;i>=0;i-- ){
     58         while( top!=tmp&&cross( res[ top ],pnt[ i ],res[ top-1 ] )>=0 )
     59             top--;
     60         res[ ++top ]=pnt[ i ];
     61     }
     62     return top;
     63 }
     64 
     65 int rotating( int n ){
     66     int q=1;
     67     int ans=0;
     68     res[ n ]=res[ 0 ];
     69     for( int i=0;i<n;i++ ){
     70         while( cross( res[ i ],res[ q+1 ],res[ i+1 ] )>cross( res[ i ],res[ q ],res[ i+1 ] ) )    
     71             q=(q+1)%n;
     72         ans=max( ans,max( dis2( res[i],res[q] ),dis2( res[i+1],res[q+1] ) ) );
     73     }
     74     return ans;
     75 }
     76 /*
     77 void test(){
     78     int sum=0;
     79     node a,b,c;
     80     a.x=a.y=1;
     81     b.x=3,b.y=1;
     82     c.x=1,c.y=7;
     83     printf("%d\n",cross(a,b,c));
     84 }    
     85 */
     86 /*
     87 void test2( int cnt ){
     88     printf("\n");
     89     for( int i=0;i<cnt;i++ )
     90         printf("%d %d\n",res[i].x,res[i].y);
     91     printf("\n");
     92 }
     93 */
     94 int main(){
     95     int n;
     96     //test();
     97     while( scanf("%d",&n)!=EOF ){
     98         for( int i=0;i<n;i++ )
     99             scanf("%d%d",&pnt[ i ].x,&pnt[ i ].y);
    100         int cnt=graham( n );
    101         //test2(cnt);
    102         printf("%d\n",rotating( cnt ));
    103     }
    104     return 0;
    105 }
    keep moving...
  • 相关阅读:
    POJ 2407 Relatives 欧拉函数
    HDU 4704 Sum 超大数幂取模
    HDU 4699 Editor 维护栈
    HDU 4696 Answers 水题
    HDU 4686 Arc of Dream 矩阵
    [转]高斯消元题集
    [转]计算几何题集
    POJ 2981 Strange Way to Express Integers 模线性方程组
    Linux 设置文件默认打开方式
    FZU 1402 猪的安家 中国剩余定理
  • 原文地址:https://www.cnblogs.com/xxx0624/p/2964252.html
Copyright © 2011-2022 走看看