• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Why so serious? --[NKU]schindlerlee

            2009年12月6日星期日.sgu124

            2009年12月6日星期日.sgu124

            sgu124:判斷點在多邊形內還是外還是邊上
            由于線段是隨機給出的,沒有順時針或者逆時針順序,所以轉角法是不能用的
            主要考慮射線法

            射線法可以參考黑數P379,有詳細的講解,也很好理解
            trick
            1.要注意平行線段的處理,其實出現射線穿過線段端點的情況,完全和可以忽略
            2.判斷線段和射線相交時,要注意判斷交點是不是在射線上也就是
            對于射線L:P0 + s*v ,(s >= 0) 要注意判斷交點在s >= 0時才算相交

            其他就沒有了。
            做sgu的題真鍛煉,已經很久沒期待過1Y了...
             1 
             2 /*
             3  * SOUR:sgu124
             4  * ALGO:computational geometry
             5  * DATE: 2009年 12月 06日 星期日 20:50:13 CST
             6  * COMM:3
             7  * */
             8 #include<iostream>
             9 #include<cstdio>
            10 #include<cstdlib>
            11 #include<cstring>
            12 #include<algorithm>
            13 using namespace std;
            14 typedef long long LL;
            15 const int maxint = 0x7fffffff;
            16 const long long max64 = 0x7fffffffffffffffll;
            17 
            18 const int N = 10100;
            19 const double eps = 1e-10;
            20 int dcmp(double x) { return (x > eps) - (x < -eps);}
            21 struct point_t {
            22     double x, y;
            23     point_t (){}
            24     point_t (double a,double b){x = a,y = b;}
            25 }p[N][2],core;
            26 point_t operator + (point_t a,point_t b) { return point_t(a.x + b.x,a.y + b.y);}
            27 point_t operator - (point_t a,point_t b) { return point_t(a.x - b.x,a.y - b.y);}
            28 double dot_mul(point_t a,point_t b) { return a.x * b.x + a.y * b.y;}
            29 double cross_mul(point_t a,point_t b) { return a.x * b.y - a.y * b.x;}
            30 double cross_mul(point_t a,point_t b,point_t c) { return cross_mul(a-c,b-c);}
            31 double dist2(point_t a,point_t b) { return (a.x-b.x)*(a.x-b.x) + (a.y-b.y)*(a.y-b.y);}
            32 
            33 bool judge(point_t a,point_t b,point_t c,point_t d)
            34 {
            35     if(dcmp(cross_mul(a-c,d-c)) * dcmp(cross_mul(b-c,d-c)) < 0) {
            36         if(dcmp(cross_mul(a-b,c-b)) > 0//射線端
            37             return true;
            38     }
            39     return false;
            40 }
            41 
            42 int n;
            43 bool rel(point_t a,point_t b,point_t c)
            44     //a 和線段bc
            45 {
            46     double tmp =(dot_mul(a-b,c-b) / dist2(b,c)) ;
            47     //printf("rel = %f\n",tmp);
            48     return tmp >= 0 && tmp <= 1;
            49 }
            50 
            51 void work()
            52 {
            53     int sum = 0;
            54     point_t to = core;
            55     to.x += 1;//隨便取的射線
            56     to.y += 7;
            57     for(int i = 0;i < n ;i++) {
            58         if(0 == dcmp(cross_mul(p[i][1- p[i][0],core-p[i][0])) &&
            59                 rel(core,p[i][0],p[i][1])) {
            60             printf("BORDER\n");
            61             return;
            62         }
            63         if(judge(p[i][0],p[i][1],core,to))
            64             sum++;
            65     }
            66     //printf("sum=%d\n",sum);
            67     if(sum & 1) {
            68         printf("INSIDE\n");
            69     }else {
            70         printf("OUTSIDE\n");
            71     }
            72 }
            73 
            74 int main()
            75 {
            76     int i,j,k;
            77     scanf("%d",&n);
            78     for(i = 0;i < n;i++) {
            79         scanf("%lf%lf%lf%lf",&p[i][0].x,&p[i][0].y,&p[i][1].x,&p[i][1].y);
            80 
            81         if(p[i][0].y < p[i][1].y) { //保證線段總是指向左上的
            82             swap(p[i][0],p[i][1]);
            83         }else if(p[i][0].y == p[i][1].y && p[i][0].x > p[i][1].x) {
            84             swap(p[i][0],p[i][1]);
            85         }
            86     }
            87     scanf("%lf%lf",&core.x,&core.y);
            88     work();
            89     return 0;
            90 }
            91 
            92 


            posted on 2009-12-06 22:46 schindlerlee 閱讀(1071) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

            99久久精品影院老鸭窝| 国产精品美女久久久久AV福利| 亚洲午夜精品久久久久久浪潮| 色综合久久中文字幕综合网| 久久综合亚洲色一区二区三区| 69SEX久久精品国产麻豆| 91精品国产高清久久久久久91| 久久久久久国产a免费观看黄色大片 | 久久精品无码午夜福利理论片| 精品水蜜桃久久久久久久| 亚洲午夜久久久久妓女影院| 情人伊人久久综合亚洲| 97精品依人久久久大香线蕉97| 国产精品热久久毛片| 人妻精品久久无码专区精东影业| 91精品国产91久久久久久青草| 伊人久久大香线焦AV综合影院| 久久精品成人免费国产片小草| 99久久超碰中文字幕伊人| 99精品国产免费久久久久久下载 | 精品国产青草久久久久福利| 久久久久国产精品熟女影院| 亚洲另类欧美综合久久图片区| 国产99久久久久久免费看| AV无码久久久久不卡网站下载| 久久久久久极精品久久久| 狠狠色丁香婷婷综合久久来来去| 久久亚洲高清观看| 女人香蕉久久**毛片精品| 久久精品亚洲日本波多野结衣| 无码人妻久久一区二区三区免费丨 | 午夜精品久久久久久| 精品多毛少妇人妻AV免费久久| 99国产欧美精品久久久蜜芽| 久久久久久亚洲AV无码专区| 久久久久久久97| 久久综合久久综合久久| 99久久亚洲综合精品成人| 久久精品国产精品亜洲毛片| 久久综合视频网站| 久久人人爽人人爽人人片AV麻烦|