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

隨筆-21  評論-10  文章-21  trackbacks-0

PKU 1066 是一道感覺很好的題,用同側異側(位置)來表示的話思路會很清晰。

首先要從起點到終點穿過一道墻,等價于起點和終點在墻的異側,這樣就清楚的表示了穿過一道墻的充要條件。

接下來也變得簡單,就是枚舉終點,終點顯然在正方形的邊上。很快能發現他們是一塊一塊的。緊鄰的交點(墻和正方形所交的點)所構成的線段上的點相對墻的位置是同側。因為他們沒有被任何墻分割開。也就不可能異側。

這樣只要分塊枚舉,一塊枚舉只需一個點。




 1 #include<iostream>
 2 #include<cmath>
 3 #include<algorithm>
 4 using namespace std;
 5 double const EPS = 1e-8;
 6 const int INF = 1<<30;
 7 
 8 int dcmp(double x){return x < -EPS ? -1 : x > EPS;}
 9 
10 struct Point{
11     double x,y;
12     Point(){}
13     Point(double a, double b):x(a), y(b){}
14     bool operator<(Point a){return atan2(y - 50, x - 50< atan2(a.y - 50, a.x - 50); }
15 }; 
16 
17 struct Line{Point a, b;};
18 
19 Point P[128], s, t;
20 Line L[36];
21 int n, cnt, best;
22 
23 double xmult(Point p1, Point p2 , Point p0)
24 {
25     return (p1.x - p0.x)*(p2.y - p0.y)-(p2.x - p0.x)*(p1.y - p0.y);
26 }
27 bool same_side(Point p1, Point p2, Line L)
28 {
29     return dcmp(xmult(L.b, p1, L.a) * xmult(L.b, p2, L.a)) >= 0;
30 }
31 
32 int main()
33 {
34     int i, j, ans;
35     best = INF; cnt = 0;
36     P[cnt++= Point(00);
37     P[cnt++= Point(1000);
38     P[cnt++= Point(0100);
39     P[cnt++= Point(100100);
40 
41     cin >> n;
42     for(i = 0; i < n; i++)
43     {
44         cin>> L[i].a.x >> L[i].a.y >> L[i].b.x >> L[i].b.y;
45         P[cnt++= L[i].a;
46         P[cnt++= L[i].b;
47     }
48     cin>> s.x >> s.y;
49 
50     sort(P, P+cnt);
51 
52     for(i = 0; i < cnt; i++ )
53     {
54         ans = 0;
55         t = Point( (P[i].x + P[(i+1)%cnt].x)/2, (P[i].y + P[(i+1)%cnt].y)/2 );
56         for(j = 0; j < n; j++)
57             if(!same_side(s, t, L[j]))ans++;
58         if(ans < best) best = ans;
59     }
60 
61     printf("Number of doors = %d\n", best+1);
62 }

 

 


posted on 2009-07-24 16:20 wangzhihao 閱讀(625) 評論(5)  編輯 收藏 引用 所屬分類: geometry

評論:
# re: pku 1066 Treasure Hunt[未登錄] 2009-09-03 13:42 | SImon
博主我想請問一下
如果我枚舉分塊的兩個端點,這樣應該也可以吧?  回復  更多評論
  
# re: pku 1066 Treasure Hunt[未登錄] 2009-09-03 13:43 | SImon
我還想請問一個問題
你判斷相交的時候為什么不需要快速排斥原理呢?  回復  更多評論
  
# re: pku 1066 Treasure Hunt 2009-09-03 19:01 | logics_space

判斷同異側要避免點在線段上的情況

之所以不要線段相交里的快速排斥原理,見原題的這句話
The interior walls always span from one exterior wall to another exterior wall  回復  更多評論
  
# re: pku 1066 Treasure Hunt[未登錄] 2009-09-03 19:49 | SImon
@logics_space
或許是我對判線段相交不大理解
大牛能解釋一下判斷線段相交的時候為什么要先用排斥原理呢?
有什么是能通過跨越原理但是通不過排斥原理的嗎?

謝謝大牛解惑~  回復  更多評論
  
# re: pku 1066 Treasure Hunt 2009-09-03 20:32 | logics_space
并不是一定要先用排斥原理,也可以不用,
如果你說的是嚴格的跨立,那通過跨立原理的必相交,必通過著排斥原理
如果是非嚴格的跨立(叉積可以==0)比如(0,0) (1,1) 和(4,4)(5,3)能過非嚴格的跨立,但過不了排斥
但(4,0)(0,4)和(3,4)(6,-2)能過排斥,也能過非嚴格的跨立  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线综合亚洲| 国产日韩欧美黄色| 欧美成人精品h版在线观看| 欧美日韩小视频| 黑人一区二区三区四区五区| 新狼窝色av性久久久久久| 亚洲欧洲一区二区三区| 欧美在线影院| 国产精品一卡| 亚洲男人第一网站| 中文精品视频一区二区在线观看| 女女同性精品视频| 极品日韩久久| 欧美国产精品日韩| 欧美freesex8一10精品| 亚洲激情国产| 亚洲黄网站在线观看| 欧美大片在线看| 9l视频自拍蝌蚪9l视频成人| 亚洲精品一区二区三区福利| 欧美人与性禽动交情品 | 欧美成人免费在线视频| 亚洲国产老妈| 亚洲精品国产精品国自产在线| 欧美激情亚洲激情| 亚洲线精品一区二区三区八戒| 日韩一区二区精品| 日韩一区二区精品在线观看| 亚洲第一福利社区| 欧美福利精品| 中文久久乱码一区二区| 国产精品99久久不卡二区| 国产欧美精品一区aⅴ影院| 久久久久国内| 欧美大片一区二区三区| 亚洲一区欧美一区| 欧美在线高清| 日韩亚洲欧美中文三级| 亚洲视频中文字幕| 激情久久久久久久| 最近看过的日韩成人| 欧美天天影院| 久久精品一区二区三区四区| 欧美**字幕| 亚洲欧美一区二区三区久久| 久久精品论坛| 亚洲午夜在线| 久久久xxx| 亚洲一区二区三区免费观看| 久久精品国产精品亚洲精品| 夜夜爽www精品| 午夜精品久久久久久久久久久| 在线观看一区| 亚洲一级免费视频| 亚洲日本激情| 久久av红桃一区二区小说| 一区二区91| 久久九九精品99国产精品| 亚洲图片欧美一区| 久久久久国产免费免费| 亚洲免费影视第一页| 欧美aaa级| 久久香蕉国产线看观看网| 欧美日韩一区二区三区在线视频| 麻豆成人精品| 国产色爱av资源综合区| 亚洲日韩欧美视频| 伊人精品久久久久7777| 亚洲综合视频一区| 日韩午夜免费| 美女国内精品自产拍在线播放| 午夜视频一区| 欧美日本在线看| 欧美激情 亚洲a∨综合| 国产综合18久久久久久| 亚洲男人第一网站| 中日韩高清电影网| 欧美激情一区二区三区在线视频观看| 久久精品国产96久久久香蕉| 国产精品久久久久久久久久久久久 | 99re6热在线精品视频播放速度| 国产亚洲视频在线观看| 亚洲午夜电影网| 亚洲人成亚洲人成在线观看| 欧美激情女人20p| 亚洲日本成人| 亚洲视频视频在线| 在线观看国产一区二区| 亚洲精品日本| 亚洲午夜精品国产| 久久成人久久爱| 国产自产2019最新不卡| 亚洲国产成人午夜在线一区| 亚洲永久网站| 亚洲欧美在线另类| 国产精品第三页| 亚洲网站在线播放| 新狼窝色av性久久久久久| 国产美女精品一区二区三区 | 一区二区三区四区国产| 亚洲性视频网站| 国产精品国产三级国产aⅴ浪潮| 99国内精品久久| 亚洲一区二区三区在线视频| 国产精品成人播放| 亚洲视频每日更新| 久久国产精品一区二区三区| 国产一本一道久久香蕉| 久久av资源网| 欧美成人黑人xx视频免费观看| 亚洲国产日韩欧美一区二区三区| 欧美国产日韩一区| 亚洲视频免费看| 久久精品视频99| 亚洲国产1区| 欧美日韩精品一区二区天天拍小说| 日韩午夜激情av| 久久精品国产第一区二区三区| 亚洲成人自拍视频| 欧美经典一区二区| 亚洲一区二区黄色| 蜜臀久久久99精品久久久久久| 亚洲精品社区| 国产精品久久久久天堂| 久久本道综合色狠狠五月| 亚洲国产成人精品女人久久久| 一区二区三区色| 狠狠色噜噜狠狠狠狠色吗综合| 欧美成人精品在线观看| 亚洲午夜视频| 亚洲第一黄网| 欧美在线免费视频| 亚洲欧洲一二三| 国产婷婷精品| 欧美日韩国产精品一区二区亚洲 | 欧美人交a欧美精品| 欧美一区免费| 亚洲精品免费在线观看| 久久―日本道色综合久久| av72成人在线| 伊人成人在线视频| 国产精品日韩二区| 欧美精品国产精品日韩精品| 亚洲精品中文字幕在线观看| 好吊色欧美一区二区三区四区| 欧美精品国产| 久久婷婷av| 亚洲一区在线观看视频 | 亚洲一区二区三区涩| 欧美黄色一区二区| 欧美在线精品免播放器视频| 亚洲精品四区| 精品动漫3d一区二区三区免费| 国产精品爱啪在线线免费观看| 久久亚洲免费| 久久激情视频| 亚洲在线黄色| 一本久久青青| 亚洲三级影院| 亚洲欧洲午夜| 亚洲国产一区二区三区在线播| 久久综合综合久久综合| 久久高清免费观看| 午夜精品久久久99热福利| 99国产精品久久久久久久成人热| 亚洲国产成人一区| 一区二区视频欧美| 黑人极品videos精品欧美裸| 国产欧美视频在线观看| 国产精品免费一区豆花| 国产精品v欧美精品v日本精品动漫 | 欧美aa在线视频| 毛片一区二区三区| 久久理论片午夜琪琪电影网| 欧美在线观看视频一区二区三区| 亚洲视频网站在线观看| 亚洲日本久久| 亚洲理伦电影| 艳妇臀荡乳欲伦亚洲一区| 日韩亚洲在线| 一本色道久久综合亚洲二区三区| 亚洲精品网站在线播放gif| 亚洲人精品午夜| 99精品视频免费| 中日韩美女免费视频网址在线观看| 亚洲精品中文字幕在线| 一区二区三区日韩欧美| 亚洲欧美日韩精品一区二区| 午夜精品久久久久久久久| 午夜精品一区二区三区在线| 欧美一区二区精美| 久久精品日韩| 欧美黑人多人双交| 欧美色网在线| 国产精品一区二区欧美| 国产日韩一级二级三级| 黄色国产精品一区二区三区| 亚洲黄色一区| 亚洲影音先锋| 久久久亚洲国产天美传媒修理工 |