• <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)  編輯 收藏 引用 所屬分類: 解題報告

            久久精品国产精品亚洲人人 | 91精品国产综合久久久久久| 久久精品国产亚洲AV无码娇色| 国内精品九九久久久精品| 国产农村妇女毛片精品久久| 亚洲国产视频久久| 99久久99这里只有免费的精品| 久久久久久国产a免费观看不卡| 大香伊人久久精品一区二区| 国产69精品久久久久777| 午夜精品久久久久久久无码| 国产精品久久午夜夜伦鲁鲁| 欧美成a人片免费看久久| av国内精品久久久久影院| 漂亮人妻被中出中文字幕久久| 久久久久综合网久久| 亚洲av日韩精品久久久久久a | 精品一区二区久久| 午夜久久久久久禁播电影| 久久久久国产一区二区| 狠狠色丁香久久综合五月| 久久人妻少妇嫩草AV蜜桃| 久久久久国产成人精品亚洲午夜| 亚洲熟妇无码另类久久久| 亚洲午夜精品久久久久久app| 精品久久久久久国产| 久久久久久毛片免费播放| 中文字幕热久久久久久久| 人人狠狠综合久久亚洲高清| 99久久久久| 国产精品美女久久久免费| 国产精品视频久久久| 一本色道久久综合亚洲精品| 亚洲精品乱码久久久久66| 亚洲国产精品无码久久久秋霞2 | 久久99精品久久久久久久不卡| 国产香蕉久久精品综合网| 久久精品国产亚洲AV蜜臀色欲 | 国内精品久久国产大陆| 狠狠88综合久久久久综合网| 久久精品无码午夜福利理论片|