青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩激情网| 亚洲视频在线观看一区| 99精品久久久| 亚洲视频综合在线| 国产精品v日韩精品| 欧美精品免费看| 欧美日韩大陆在线| 国产精品久久久久77777| 国产精品影音先锋| 在线观看三级视频欧美| 99视频一区二区| 欧美一区二区三区在线观看| 久久久久久一区二区三区| 欧美91大片| 一本一道久久综合狠狠老精东影业| 国产精品99久久久久久人| 欧美一区2区三区4区公司二百| 久久天天综合| 国产精品高潮呻吟久久av黑人| 国内在线观看一区二区三区| 亚洲三级影院| 久久精品视频免费| 亚洲精品久久久久久下一站| 午夜精品国产精品大乳美女| 免费影视亚洲| 国产精品一区二区黑丝| 亚洲黄色精品| 久久久久免费观看| 日韩一区二区精品在线观看| 久久久www成人免费毛片麻豆| 欧美精品久久久久久久久久| 国产在线观看91精品一区| 99热在这里有精品免费| 久久免费视频在线| 亚洲视频在线一区观看| 欧美丰满少妇xxxbbb| 韩国成人精品a∨在线观看| 亚洲午夜国产成人av电影男同| 免费视频亚洲| 香蕉国产精品偷在线观看不卡| 欧美日韩高清在线观看| 亚洲国产精品www| 久久久久免费视频| 午夜激情一区| 欧美性一区二区| 夜夜嗨一区二区三区| 你懂的亚洲视频| 久久成人免费网| 国产一区二区无遮挡| 性久久久久久| 亚洲影院免费观看| 国产精品美女诱惑| 亚洲欧美文学| 亚洲一卡二卡三卡四卡五卡| 欧美视频在线视频| 亚洲欧美另类在线| 中文在线资源观看视频网站免费不卡| 欧美精品一区二区三区一线天视频| 亚洲国产精品久久久久| 欧美大片一区二区| 麻豆久久精品| 亚洲精品免费一二三区| 亚洲二区三区四区| 樱桃视频在线观看一区| 久久这里只有| 久久久久久久久久看片| 一色屋精品视频免费看| 久久久蜜桃一区二区人| 久久精品一区二区| 亚洲激情在线播放| 亚洲黄色在线| 欧美日韩在线直播| 欧美一级播放| 久久精品导航| 亚洲欧洲一区二区天堂久久| 亚洲第一在线综合网站| 欧美日韩国产片| 午夜精品国产更新| 欧美一区国产二区| 在线免费观看视频一区| 亚洲电影成人| 国产精品福利久久久| 久久国产综合精品| 老司机成人在线视频| 99视频一区| 亚洲自拍都市欧美小说| 黄网动漫久久久| 亚洲日韩视频| 国产女主播视频一区二区| 久久精品国产第一区二区三区最新章节 | 久久亚洲国产精品日日av夜夜| 狠狠色综合日日| 亚洲国产欧美国产综合一区| 国产精品v亚洲精品v日韩精品| 欧美一区二区大片| 久久久人人人| 午夜精品久久久久久久| 久久久精品久久久久| 日韩一区二区福利| 午夜精品久久久久久久久久久久| 亚洲高清在线播放| 中文一区在线| 亚洲精品国久久99热| 午夜精品久久久久久久99樱桃 | 亚洲欧美中文另类| 久久精彩免费视频| 亚洲视频在线观看| 久久国产色av| 亚洲欧美日韩精品久久亚洲区 | 一本在线高清不卡dvd| 极品少妇一区二区| 一区二区三区四区国产| 1000部国产精品成人观看| 在线午夜精品自拍| 亚洲激精日韩激精欧美精品| 亚洲欧美综合国产精品一区| 欧美揉bbbbb揉bbbbb| 狠狠色狠狠色综合系列| 亚洲另类自拍| 亚洲高清视频的网址| 亚洲字幕一区二区| 一区二区三区视频在线观看| 久久这里只有| 久久久久久国产精品mv| 国产精品久久久久久影视| 亚洲国产精品久久久久婷婷老年| 国产一区二区三区免费在线观看| 99精品欧美一区二区蜜桃免费| 亚洲激情视频网站| 久久久精品一区| 久久国产欧美日韩精品| 国产精品国产三级国产专播品爱网 | 欧美日韩国产色综合一二三四| 麻豆91精品| 国内精品久久久久久久影视蜜臀| 亚洲视频一区二区免费在线观看| av成人免费| 欧美福利网址| 亚洲精品日韩精品| 日韩一区二区精品葵司在线| 欧美福利影院| 91久久亚洲| 日韩视频中午一区| 欧美激情第10页| 日韩午夜精品| 亚洲欧美日韩国产一区| 国产精品私房写真福利视频| 一本色道88久久加勒比精品| 在线中文字幕日韩| 欧美三区免费完整视频在线观看| 日韩网站在线| 亚洲自拍偷拍福利| 国产精品一页| 久久久蜜桃一区二区人| 欧美电影打屁股sp| 99国内精品久久| 欧美视频观看一区| 亚洲欧美日韩系列| 蜜桃av久久久亚洲精品| 亚洲国产一区二区a毛片| 欧美精品一区二区三区高清aⅴ| 亚洲精品中文字| 欧美一区二区视频在线| 韩国av一区二区| 欧美日韩和欧美的一区二区| 亚洲欧美日韩一区| 亚洲福利视频三区| 亚洲综合另类| 在线精品国产成人综合| 欧美高清在线| 香蕉免费一区二区三区在线观看| 麻豆精品精华液| 亚洲一区二区综合| 国内揄拍国内精品少妇国语| 欧美本精品男人aⅴ天堂| 在线亚洲一区| 欧美jizz19hd性欧美| 亚洲素人一区二区| 伊人婷婷久久| 欧美午夜一区二区福利视频| 久久精品视频播放| 老司机精品视频网站| 亚洲影院在线| 欧美日韩精品一区| 欧美一站二站| 99re热精品| 日韩一区二区精品葵司在线| 国产手机视频精品| 亚洲一区三区电影在线观看| 欧美夫妇交换俱乐部在线观看| 国产欧美精品一区aⅴ影院| 米奇777超碰欧美日韩亚洲| 久久精品日韩欧美| 一区二区三区精品视频| 黄色日韩精品| 国产乱码精品一区二区三| 欧美区在线播放| 欧美成年人在线观看| 久久久www| 欧美影院成人|