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

Why so serious? --[NKU]schindlerlee

2010年02月13日星期六.sgu174 并查集+二叉搜索樹

2010年02月13日星期六.sgu174
sgu174:并查集+二叉搜索樹
說說題意吧。就是每次給出兩個點,這兩個點代表一條線段,如果這一條線段能和已經存在的線
段構成一個封閉多邊形,那么就輸出這是第幾條線段。

很自然的能想到并查集,所差的就是為每一個點賦予一個唯一的編號。
如果線性的查找已經處理過的點,那么就每次查詢的復雜度就是O(n).
而有n個這樣的查詢。當n如此大的時候,n^2的算法顯然會超時。

我們需要提高每次查詢的復雜度。
其實很容易就能想到二叉搜索樹。不想寫的話可以直接使用stl中的map,map是紅黑樹的實現,如
果不怕常數復雜度的話,這是一個很好的想法。

還有就是并查集,并查集需要加上路徑壓縮,不然很容易超時。

 1 
 2 const int N = 400010;
 3 struct point_t {
 4     int x,y;
 5     point_t(){}
 6     point_t(int a,int b){x = a,y = b;}
 7 }a,b;一bool operator < (point_t a,point_t b)
 8 {
 9   if (a.x != b.x) {
10       return a.x < b.x;
11   }
12   return a.y < b.y;
13 }
14 map<point_t,int> g;
15 int n, p[N],rank[N];
16 
17 int findset(int x)
18 {
19   if (p[x] != x) {
20       p[x] = findset(p[x]);
21   }
22   return p[x];
23 }
24 //http://m.shnenglu.com/schindlerlee
25 bool unionset(int x,int y)
26 {
27   x = findset(x);
28   y = findset(y);
29   if (x == y) { return true; }
30   if (rank[x] > rank[y]) {
31       p[y] = x;
32   } else if (rank[x] < rank[y]) {
33       p[x] = y;
34   } else if (rank[x] == rank[y]) {
35       p[x] = y;
36       rank[y]++;
37   }
38   return false;
39 }
40 
41 int main()
42 {
43   int i,ia,ib;
44   scanf("%d",&n);
45   for (i = 0;i < N;i++) { p[i] = i; }
46   for (i = 1;i <= n;i++) {
47       scanf("%d%d%d%d",&a.x,&a.y,&b.x,&b.y);
48       if ((ia = g[a]) == 0) { ia = g[a] = i << 1; } //from 1
49       if ((ib = g[b]) == 0) { ib = g[b] = (i << 1+ 1; }
50       if (unionset(ia,ib)) {
51           printf("%d\n",i);
52           break;
53       }
54   }
55   if (i > n) {
56       printf("0\n");
57   }
58   return 0;
59 }
60 


posted on 2010-02-14 00:38 schindlerlee 閱讀(1582) 評論(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>
            亚洲一区二区免费看| 国内久久精品| 国产一区二区三区在线观看免费视频 | 久久人人看视频| 亚洲天堂久久| 在线日韩精品视频| 亚洲欧美在线播放| 久久精品视频va| 洋洋av久久久久久久一区| 日韩视频精品在线观看| 欧美激情综合亚洲一二区| 亚洲麻豆av| 日韩亚洲不卡在线| 国产精品美女久久久久av超清| 欧美在线影院在线视频| 久久在线免费观看| 亚洲天堂成人在线观看| 久久久久久**毛片大全| 在线亚洲一区| 久久综合网络一区二区| 亚洲免费在线观看| 美女视频黄免费的久久| 性8sex亚洲区入口| 欧美日韩午夜在线| 欧美激情国产日韩精品一区18| 欧美日韩国产综合网| 欧美3dxxxxhd| 尤物在线精品| 久久久久网址| 欧美激情一区二区三区| 中日韩午夜理伦电影免费| 亚洲第一精品福利| 国产亚洲一区二区精品| 久久精品国产欧美激情 | 美腿丝袜亚洲色图| 一本色道久久综合亚洲精品小说| 国产情侣一区| 亚洲精品专区| 午夜在线播放视频欧美| 国产一区二区三区久久 | 亚洲激情在线视频| 欧美电影免费观看高清完整版| 亚洲精品一区在线| 亚洲欧美精品在线| 在线观看成人av电影| 欧美日韩精品免费观看视频| 亚洲一线二线三线久久久| 欧美亚洲三级| 在线亚洲一区| 影音先锋日韩有码| 欧美视频一区二区三区在线观看| 亚洲一区二区三区高清不卡| 卡通动漫国产精品| 久久成人免费网| 99视频超级精品| 亚洲欧洲精品一区二区精品久久久| 欧美午夜欧美| 欧美电影免费| 麻豆精品在线视频| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产成人porn| 久久一区二区三区国产精品| 亚洲一区国产| 亚洲天堂av高清| 亚洲专区一区二区三区| 一区二区欧美亚洲| 欧美不卡在线视频| 久久精品日产第一区二区| 99re热这里只有精品免费视频| 欧美岛国激情| 亚洲高清123| 亚洲国产毛片完整版| 久久偷窥视频| 美女国内精品自产拍在线播放| 欧美在线不卡| 免费观看成人www动漫视频| 久久精品导航| 欧美激情亚洲另类| 亚洲六月丁香色婷婷综合久久| 一二美女精品欧洲| 欧美一级视频一区二区| 久久亚洲一区二区| 欧美精品福利在线| 国产精品美女主播| 狠狠色狠狠色综合系列| 亚洲精品一区在线| 午夜精品久久久久久久久 | 亚洲午夜久久久| 午夜精品在线| 欧美www在线| 欧美日韩xxxxx| 国产亚洲精品久久久久动| 亚洲九九九在线观看| 亚洲性线免费观看视频成熟| 亚洲视频在线播放| 久久青草久久| 欧美日韩亚洲一区二区| 国产午夜亚洲精品羞羞网站| 精品成人免费| 欧美一区二区三区播放老司机| 美女999久久久精品视频| 一本久道久久综合中文字幕| 久久精品人人爽| 国产一区二区三区久久久久久久久| 亚洲激情成人| 免费亚洲电影在线| 久久精品最新地址| 夜夜嗨av一区二区三区四季av | 午夜精品福利在线观看| 欧美日韩国产综合久久| 亚洲精品国产精品国自产在线| 久久久久久久久久看片| 亚洲新中文字幕| 国产精品一二三| 欧美一区二区三区另类 | 国产精品白丝jk黑袜喷水| 亚洲全黄一级网站| 亚洲精品国产系列| 欧美另类视频| 亚洲欧美精品在线观看| 中日韩午夜理伦电影免费| 欧美午夜精品久久久久免费视| 在线午夜精品自拍| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲电影免费| 亚洲精品国精品久久99热| 国产精品欧美日韩| 另类尿喷潮videofree| 欧美久久99| 久久精品亚洲| 欧美三级欧美一级| 久久亚洲精品网站| 国产精品每日更新| 欧美aa在线视频| 国产日韩欧美一二三区| 亚洲国产小视频| 激情丁香综合| 亚洲午夜一区二区| 欧美在线看片| 亚洲综合色网站| 老色鬼久久亚洲一区二区| 亚洲图片激情小说| 一区二区av在线| 性伦欧美刺激片在线观看| 一区二区三区在线观看欧美| 国产精品视频免费| 亚洲激情一区二区| 激情国产一区| 午夜日韩激情| 午夜精品短视频| 国产精品久久毛片a| 一区二区高清视频在线观看| 在线国产精品一区| 久久久国产一区二区| 欧美黄色视屏| 欧美成人中文字幕在线| 狠狠综合久久av一区二区小说 | 久久嫩草精品久久久精品| 欧美成人免费播放| 亚洲破处大片| 亚洲伊人久久综合| 国产精品久久97| 亚洲一区二区三区欧美 | 久久青草福利网站| 激情五月婷婷综合| 蜜臀久久久99精品久久久久久| 亚洲国产美女| 亚洲深夜福利网站| 国产精品色婷婷| 蜜桃精品一区二区三区| 亚洲欧洲三级| 久久精品99| 亚洲视频大全| 在线欧美日韩精品| 国产精品国产福利国产秒拍| 欧美一区二区三区免费大片| 久久亚洲欧美| 久久成人羞羞网站| 夜夜爽99久久国产综合精品女不卡| 国产精品一区视频| 欧美国产日韩精品| 久久久久国产一区二区三区四区| 亚洲精品国产精品乱码不99| 久久久久久欧美| 亚洲一区二区三区四区在线观看| 一区二区在线观看视频| 亚洲欧洲日产国产网站| 亚洲欧美第一页| 亚洲激情影院| 亚洲国产精品999| 国产亚洲精品综合一区91| 欧美日韩一区二区三区免费| 免费精品99久久国产综合精品| 亚洲福利专区| 久久综合久久美利坚合众国| 一区二区三区四区五区精品视频 | 国产精品女人网站| 欧美日本一区二区高清播放视频| 欧美在线观看一区二区三区| 亚洲天堂成人|