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

“掃描線”思想的應用

Posted on 2011-12-25 16:10 Mato_No1 閱讀(399) 評論(0)  編輯 收藏 引用
【本沙茶以前曾經搞過矩形的面積并、周長并問題,當時幾乎是抄神犇代碼的,根本木有理解,現在在看了掃描線以后理解一些了】
“掃描線”嚴格來說不是算法,而是一種思想,它在解決很多幾何問題或者矩陣問題中有大用。所謂“掃描線”,就是用一條假想的直線(一般是水平或者豎直的)沿x軸(或y軸)方向掃過整個平面,在此過程中,每當發現有特殊事件(比如插入、刪除事件等),就執行這一事件。一般來說,它需要配合數據結構進行加速,常用的數據結構有線段樹、平衡樹、樹狀數組、堆、凸多邊形集合等。

【1】矩形的面積并和周長并問題:
這個在以前總結的那一篇里面曾經說明過,這里只是補充一下。

對于面積并,可以假想一條水平直線沿y軸正方向掃過整個平面,每當遇到矩形的上下邊界,就插入或刪除一條線段(上邊界為插入,下邊界為刪除),在每兩個相鄰上下邊界之間得到覆蓋面積為:目前插入(尚未刪除)的所有線段覆蓋的總長度乘以兩邊界間的距離。顯然,求前者需要用離散化(橫坐標)+線段樹實現。

這里講一下離散化的步驟和易疵點:首先將要離散化的數據(設為A數組)存儲在一個數組B里,然后對B排序(一般是遞增排序)、去重(方法:若B長度為0則不需去重,否則B[0]保留,從B[1]開始,若B[i]>B[i-1]則保留B[i]否則跳過B[i]),得到一個新的數組B0,最后,再對原來的A數組中的每個元素在B0中二分查找,找到其位置即可。顯然,對N個數據離散化時間復雜度為O(NlogN),具體實現時,可不設B0,直接存在B里面(見代碼)。易疵的地方主要是B的長度為0的情況。
re(i, n0) B[i] = A[i].x;
qsort(B, n0, 
sizeof(B[0]), cmp);
= 1; re2(i, 1, n0) if (B[i] > B[i - 1]) B[n++= B[i];
re(i, n0) A[i].x 
= find_x(A[i].x);
其中n0為數據個數,n為去重后的數據個數(也就是離散化后的編號范圍,很重要的!),find_x為二分查找過程。

對于周長并可以這樣理解:照樣是水平直線沿y軸正方向掃過整個平面,照樣是遇到矩形的上下邊界就插入或刪除,這樣,周長的水平部分是很好得到的,只要統計每兩個相鄰上下邊界的線段覆蓋總長之差即可,對于豎直部分則需要統計被線段覆蓋的端點個數——或者說,需要統計至少作為一條目前插入線段的端點,且木有被任何一條線段部包含的端點個數(因為只有這些點所延伸下來的豎直線段有可能作為周長的豎直部分)。維護方法:給每個結點設立ss、lbd與rbd,分別表示該結點區間內這種點的個數,以及該線段區間的左右端點是不是這種點。lbd=LCH.lbd; rbd=RCH.rbd; ss=LCH.ss+RCH.ss-2*(LCH.rbd || RCH.lbd)(因為我們需要的是線段樹而不是點樹,因此其中的每個葉結點表示的實際上是一條單位線段,而不是一個點,這樣,LCH區間的右端點與RCH區間的左端點其實是同一個點,如果它們都是這種點,則都不能算,因為被包含在內部了)。例外的是,如果某個結點區間完全被某條插入線段包含,則ss為2,lbd、rbd均為1(這個結果可能不正確,因為可能左右端點被包含在內部,因此,整棵樹上只有根結點的ss值是絕對正確的ss值,其余結點都需要特判)。這樣,根結點的ss值就是這種點的個數,乘以兩相鄰上下邊界的距離就是之間的豎直部分總長度。

代碼:
面積并(HDU1542)
周長并(HDU1828)

(此外,周長并還有一種更容易理解的算法:就是先求出水平部分總長后,將所有的矩形旋轉90度,再求一次水平部分總長,這就是原來的豎直部分總長了)

【2】應用:
PKU2482
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            夜夜嗨av一区二区三区网页| 中文一区字幕| 欧美日韩免费视频| 欧美精品久久久久久久久老牛影院 | 亚洲电影免费观看高清完整版在线| 欧美专区日韩专区| 久久久女女女女999久久| 久久久久久97三级| 欧美国产精品中文字幕| 亚洲精品1区| 一本久久a久久精品亚洲| 亚洲欧美区自拍先锋| 久久国内精品视频| 欧美α欧美αv大片| 欧美日韩在线视频首页| 国产丝袜一区二区三区| 亚洲国产日韩欧美一区二区三区| 亚洲精品国产精品国自产在线| 宅男在线国产精品| 亚洲影院色无极综合| 亚洲在线一区二区| 久久婷婷国产综合精品青草 | 亚洲精品乱码| 亚洲综合大片69999| 久久成人免费网| 欧美精品在线播放| 国产专区欧美专区| 在线视频一区二区| 免费久久久一本精品久久区| 一本久道综合久久精品| 久久男人资源视频| 欧美午夜免费| 日韩一级黄色大片| 免费久久99精品国产| 午夜精品国产更新| 欧美激情性爽国产精品17p| 国产欧美日韩在线| 中国女人久久久| 欧美国产日韩二区| 午夜激情综合网| 免费亚洲电影在线| 午夜精品久久久久影视| 国产亚洲欧美色| 欧美成人免费在线| 国产欧美日韩综合精品二区| 日韩亚洲不卡在线| 欧美激情精品久久久久久黑人| 午夜精品福利视频| 国产精品麻豆欧美日韩ww| 亚洲日本国产| 久久夜色精品亚洲噜噜国产mv| 中文在线资源观看网站视频免费不卡 | 国产精品网站在线| 一区二区三区蜜桃网| 欧美高清在线视频| 久久久久久欧美| 激情久久五月天| 国产午夜精品全部视频在线播放| 一本大道久久a久久精品综合| 欧美成人高清视频| 玖玖视频精品| 亚洲精品日韩激情在线电影| 欧美激情精品久久久六区热门| 久久久福利视频| 一色屋精品视频免费看| 久久亚洲图片| 免费成人性网站| 亚洲精品国产欧美| 亚洲高清网站| 欧美日韩亚洲综合| 亚洲专区国产精品| 亚洲一区二区三区四区五区午夜| 国产精品尤物| 久久久久99| 久久久久久9| 亚洲精品小视频在线观看| 亚洲三级视频在线观看| 欧美日韩性生活视频| 亚洲欧美日韩成人| 欧美一级午夜免费电影| 亚洲国产mv| 日韩亚洲欧美一区| 国产欧美一区二区精品仙草咪 | 欧美精品一区二区三区高清aⅴ| 亚洲国产小视频| 亚洲精品免费在线| 国产精品区一区二区三| 久久蜜臀精品av| 欧美另类亚洲| 久久精品123| 欧美国产极速在线| 久久国产视频网| 欧美日本亚洲韩国国产| 欧美一区二区在线观看| 久久人人97超碰人人澡爱香蕉| 国产精品久久久久久久久久久久久久| 欧美国产一区视频在线观看| 亚洲视频每日更新| 欧美影院在线| 一本色道久久综合亚洲精品小说 | 国产精品久久久久久亚洲调教| 午夜精品久久久久影视| 久久久精品免费视频| 夜夜爽www精品| 久久国产欧美日韩精品| 亚洲午夜免费视频| 久久综合色婷婷| 亚洲制服丝袜在线| 欧美成人亚洲| 久久综合给合久久狠狠色 | 狼人社综合社区| 亚洲一区二区三区三| 久久午夜电影| 亚洲欧美日韩一区在线观看| 欧美不卡视频| 美女视频黄免费的久久| 国产欧美日韩一区| 中日韩男男gay无套| 最新日韩在线视频| 久久九九精品99国产精品| 亚洲欧美日韩在线| 欧美视频在线观看| 亚洲欧洲日本国产| 亚洲第一页自拍| 欧美在线国产精品| 久久精品91| 国产一区自拍视频| 欧美一区二区三区电影在线观看| 亚洲欧美成人一区二区三区| 欧美日韩第一区| 亚洲激情在线观看视频免费| 在线欧美视频| 蜜桃伊人久久| 亚洲国产婷婷香蕉久久久久久99| 伊人久久大香线蕉综合热线| 久久国产精品99久久久久久老狼| 午夜精品美女久久久久av福利| 欧美日韩一区二区三区在线看 | 亚洲狼人精品一区二区三区| 亚洲精品美女91| 欧美啪啪成人vr| 一区二区电影免费观看| 亚洲在线观看视频网站| 国产精品日本精品| 亚洲男同1069视频| 欧美一区二区三区在线播放| 国产伦精品一区二区三区| 亚洲欧美在线另类| 久久久久免费观看| 在线激情影院一区| 欧美aⅴ一区二区三区视频| 亚洲国产你懂的| 亚洲视频日本| 免费成人小视频| 免费观看成人| 欧美激情亚洲另类| 亚洲美女av网站| 欧美三级欧美一级| 亚洲午夜女主播在线直播| 亚洲欧美三级伦理| 国产伦精品一区二区三区四区免费| 亚洲一区欧美一区| 久久久久国产精品一区二区| 在线观看亚洲视频| 欧美黄色影院| 亚洲一区二区三区成人在线视频精品| 欧美自拍偷拍午夜视频| 伊人久久大香线| 欧美日韩色综合| 欧美一区二区三区日韩视频| 欧美福利在线| 亚洲欧美bt| 亚洲国产天堂久久综合| 国产精品高潮呻吟久久| 久久五月婷婷丁香社区| 99这里只有久久精品视频| 久久www成人_看片免费不卡| 亚洲国产精品va| 国产精品―色哟哟| 欧美电影美腿模特1979在线看| 亚洲网站在线看| 亚洲福利在线观看| 久久久久久久一区二区三区| 妖精视频成人观看www| 好男人免费精品视频| 欧美午夜美女看片| 美女视频黄免费的久久| 欧美一区二区精品久久911| 亚洲精品网址在线观看| 噜噜噜91成人网| 欧美在线视频在线播放完整版免费观看 | 亚洲一区二区三区激情| 欧美成人久久| 久久久99国产精品免费| 亚洲一二三区视频在线观看| 亚洲日本在线视频观看| 国模私拍视频一区| 国产精品人人爽人人做我的可爱 | 免费短视频成人日韩| 欧美在线www|