我希望你是我独家记忆

一段永远封存的记忆,随风而去
posts - 263, comments - 31, trackbacks - 0, articles - 3
   :: 首页 :: 新随笔 ::  :: 聚合  :: 管理

NBU——1185(点在多边形内)

Posted on 2008-08-29 20:28 Hero 阅读(131) 评论(0)  编辑 收藏 引用 所属分类: 代码如诗--ACM
  1 #include <stdio.h>
  2 #include <stdlib.h>
  3 #include <string.h>
  4 
  5 #define eps 1e-8
  6 #define zero(x) ( ((x)>0?(x):-(x))<eps )
  7 #define _sign(x) ((x)>eps?1:((x)<-eps?2:0))
  8 
  9 struct Point
 10 {
 11     double x ;
 12     double y ;
 13 };
 14 struct Point point[4] ;
 15 
 16 double minx, miny ;
 17 double maxx, maxy ;
 18 
 19 double fmax( double a, double b ) 
 20 {
 21     if( a - b > 0 )    return a ;
 22     else return b ;
 23 }
 24 double fmin( double a, double b )
 25 {
 26     if( a - b < 0 )    return a ;
 27     else return b ;
 28 }
 29 
 30 double xmult( Point p1, Point p2, Point p0 ) {
 31     return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y);
 32 }
 33 
 34 //判点在凸多边形内或多边形边上,顶点按顺时针或逆时针给出
 35 int inside_convex( Point q, int n, Point* p ) {
 36     int s[3]={1,1,1};
 37     for ( int i=0;i<n&&s[1]|s[2];i++ )
 38         s[_sign(xmult(p[(i+1)%n],q,p[i]))]=0;
 39     return s[1]|s[2];
 40 }
 41 
 42 int main()
 43 {
 44     while( scanf( "%lf %lf",&point[0].x,&point[0].y ) )
 45     {
 46         minx = 500 ; miny = 500 ;
 47         maxx = -100 ; maxy = -100 ;
 48 
 49         minx = fmin( minx, point[0].x ) ;
 50         miny = fmin( miny, point[0].y ) ;
 51         maxx = fmax( maxx, point[0].x ) ;
 52         maxy = fmax( maxy, point[0].y ) ;
 53 
 54         scanf( "%lf %lf",&point[1].x,&point[1].y ) ;
 55 
 56         minx = fmin( minx, point[1].x ) ;
 57         miny = fmin( miny, point[1].y ) ;
 58         maxx = fmax( maxx, point[1].x ) ;
 59         maxy = fmax( maxy, point[1].y ) ;
 60 
 61         scanf( "%lf %lf",&point[2].x,&point[2].y ) ;
 62 
 63         minx = fmin( minx, point[2].x ) ;
 64         miny = fmin( miny, point[2].y ) ;
 65         maxx = fmax( maxx, point[2].x ) ;
 66         maxy = fmax( maxy, point[2].y ) ;
 67 
 68         bool isbreak = true ;
 69         forint i=0; i<3; i++ )
 70         {
 71             if!zero(point[i].x) )
 72             {
 73                 isbreak = false ; break ;
 74             }
 75             if!zero(point[i].y) )
 76             {
 77                 isbreak = false ; break ;
 78             }
 79         }
 80         if( isbreak )    break ;
 81 
 82         int mini = (int)minx ; int maxi = (int)maxx + 1 ;
 83         int minj = (int)miny ; int maxj = (int)maxy + 1 ;
 84 
 85         int out = 0 ; struct Point q ;
 86         forint i=mini; i<=maxi; i++ )
 87         {
 88             forint j=minj; j<=maxj; j++ )
 89             {
 90                 q.x = i ; q.y = j ;
 91                 if( inside_convex( q, 3, point ) ) out++ ;
 92             }
 93         }
 94 
 95         printf( "%4d\n"out ) ;
 96     }
 97 
 98     return 0 ;
 99 }
100 


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理