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

隨筆-80  評論-24  文章-0  trackbacks-0
問題一:求N個點中斜率最大的兩個點。
要解決該問題,我們首先證明一個結論:三個點a、b、c,若xa < xb < xc則斜率最大者必定是ab或者是bc,而不會是ac。證明如下:
我們用k表示斜率,
不妨假設kac > kab,即(yc - ya)/(xc - xa) - (yb - ya)/(xb - xa) > 0
則可以推出xa * yb + xb * yc + xc * ya > xa * yc + xb * ya + xc * yb
那么可以得出kbc - kac = (yc - yb)/(xc - xb) - (yc - ya)/(xc - xa)  = (xa * yb + xb * yc + xc * ya) - (xa * yc + xb * ya + xc * yb) > 0
所以可以知道如果ac斜率大于ab,那么它就不可能大于bc
同理可以得出若ac斜率大于bc,那么它就不可能大于ab
證畢。
有了上面的證明,我們就可以先對N個點的橫坐標排序,然后再計算a[i]與a[i + 1]的斜率,取最大值即可。
代碼略。

問題二:求N個點中距離最遠的兩點距離。
典型的求凸包直徑問題,這里先講解一下如何利用Graham scanning方法在O(nlogn)時間內求凸包,然后利用旋轉卡殼法在O(n)時間內求凸包直徑。
該問題面試中一般不會問到,太過復雜,不過應該學習這種思想。
1)Graham scanning求凸包:
首先:選取N個點中y坐標最小的點為P0,若有多個點y坐標相同,則取x坐標最小的點為P0,即P0為坐標系中左下角的點。
然后:根據direction(P0, Pi, Pj)來排序,direction()函數是求P0Pi向量和P0Pj向量的叉積,叉積的作用是判定P0Pi向量在P0Pj向量的逆時針方向還是順時針方向,如果P0Pi X P0Pj > 0則說明P0Pi在P0Pj的順時針方向,否則在逆時針方向。另外叉積的值的絕對值還表示以P0PiPj三點組成的三角形的面積,因為P0Pi X P0Pj = |P0Pi| * |P0Pj| * sin∠PiP0Pj,這個結論會在卡殼時用到。有了上面的知識,可以知道排序后的結果是所有節點圍繞P0以逆時針方向排列。
再次:將點P0和點P1入棧,然后從P2到Pn循環執行下面操作:若direction(Pstack[top - 1], Pstack[top], Pi) < 0,則刪除棧頂元素,即top--(因為排序的時候,如果兩個節點對P0的向量叉積若相等,則距離P0遠的節點排在后面,所以這里如果上述等式等于0的話則可以肯定Pi到Pstack[top - 1]的距離比Pstack[top]到Pstack[top - 1]的距離遠,所以可以直接將Pstack[top]出棧,當然也可以不出棧,因為某個在凸包多邊形的某條邊上的點,可以算作凸包的點,也可以去掉),否則Pi進棧。直到Pn判斷完畢。
最后:棧stack中的所有點就是凸包多邊形的點,并且從棧底到棧頂以逆時針排列。
上面算法表述的比較羅嗦,看下面的圖示就明白了:
首先是排序,然后是P0和P1入棧:



然后是判斷P2是否應該入棧:



因為P0P1 X P0P2 > 0,所以P2入棧:



然后判斷P3是否應該入棧:



因為P1P2 X P1P3 < 0,所以P2出棧P3入棧:



判斷P4是否應該入棧:



因為P1P3 X P1P4 > 0,所以P4入棧:



判斷P5是否應該入棧:



因為P3P4 X P3P5 > 0,所以P5入棧:



判斷P6是否應該入棧:



因為P4P5 X P4P6 < 0,所以p5出棧P6入棧:



最后p7入棧,形成最終的凸包:



通過以上圖示過程可以清晰明白凸包的構建過程。證明過程比較復雜,詳見《算法導論》。
posted on 2012-09-07 12:56 myjfm 閱讀(586) 評論(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>
            亚洲一级黄色片| 欧美亚洲视频在线看网址| 欧美三区在线观看| 欧美视频在线观看 亚洲欧| 欧美日韩福利| 欧美日韩在线视频一区| 国产精品一区二区三区四区| 国产精品美女久久久久久2018| 国产欧美日韩不卡免费| 在线成人国产| 亚洲综合999| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲高清资源综合久久精品| 亚洲精品免费在线| 欧美一级在线视频| 欧美岛国激情| 国产乱子伦一区二区三区国色天香 | 亚洲一区二区免费视频| 欧美一级视频免费在线观看| 免费观看一区| 国产日韩欧美综合一区| 亚洲免费av网站| 久久精品日韩欧美| 日韩视频免费大全中文字幕| 久久国产精品久久w女人spa| 欧美片网站免费| 国内精品免费午夜毛片| 在线一区免费观看| 欧美va亚洲va国产综合| 一二三区精品| 欧美 亚欧 日韩视频在线| 国产精品一区久久| 中文精品视频一区二区在线观看| 久久久久国产一区二区三区| 亚洲麻豆视频| 欧美成人精精品一区二区频| 国产综合一区二区| 午夜一级在线看亚洲| 亚洲日本精品国产第一区| 久久精品国产综合精品| 国产精品一区在线观看你懂的| 99在线热播精品免费| 欧美国产综合| 久久精品色图| 国产婷婷色一区二区三区| 亚洲欧美精品在线观看| 一个人看的www久久| 欧美日韩免费观看一区=区三区| 91久久在线| 亚洲高清资源| 欧美久久久久中文字幕| av成人激情| 亚洲在线免费观看| 国产精品日韩二区| 一本色道久久| 亚洲区第一页| 欧美精品亚洲精品| 亚洲欧洲精品一区二区三区 | 欧美福利视频| 久久一二三四| 亚洲国产一区二区a毛片| 男人的天堂成人在线| 久久精品视频在线观看| 伊人激情综合| 亚洲大片在线| 欧美日韩亚洲不卡| 亚洲一区二区三区色| 一区二区三区欧美日韩| 国产精品视频免费在线观看| 久久成人免费电影| 久久激情网站| 亚洲精品视频啊美女在线直播| 亚洲国产精品久久久久婷婷884| 欧美成人一区在线| 亚洲新中文字幕| 性伦欧美刺激片在线观看| 伊人成人在线| 亚洲精品久久在线| 国产精品一区2区| 麻豆成人在线| 欧美另类综合| 久久精品视频在线免费观看| 久久久亚洲国产天美传媒修理工| 亚洲国产片色| 一区二区三区四区五区精品| 国产乱子伦一区二区三区国色天香| 久久一区二区三区超碰国产精品| 欧美成人精品一区| 亚欧成人在线| 欧美激情精品久久久久久黑人 | 亚洲福利精品| 国产精品家教| 欧美高清视频免费观看| 欧美色精品天天在线观看视频| 久久精品国产综合精品| 欧美精品啪啪| 久久躁狠狠躁夜夜爽| 欧美日韩在线观看一区二区三区| 久久精品国产亚洲高清剧情介绍| 欧美成人午夜剧场免费观看| 欧美一级视频| 欧美另类一区二区三区| 久久免费高清| 国产精品久久久久高潮| 亚洲国产精品一区二区www| 国产麻豆午夜三级精品| 亚洲国产影院| 影音先锋国产精品| 亚洲欧美精品| 亚洲一区视频| 欧美欧美在线| 亚洲国产91色在线| 很黄很黄激情成人| 亚洲一区影音先锋| 欧美伦理在线观看| 国产精品99久久久久久久女警| 欧美一区二区三区男人的天堂| aa成人免费视频| 你懂的成人av| 免费视频一区二区三区在线观看| 国产精品红桃| 亚洲最新在线| 99视频一区二区三区| 欧美mv日韩mv国产网站app| 久久久国产一区二区| 国产精品亚洲аv天堂网| 一区二区冒白浆视频| 99亚洲一区二区| 欧美日本一区二区视频在线观看 | 亚洲电影免费观看高清| 在线播放不卡| 久久久久国产免费免费| 久久久久九九九| 激情文学一区| 久久久久久尹人网香蕉| 久久女同互慰一区二区三区| 国产一区二区精品久久91| 性色av一区二区怡红| 久久精品亚洲一区二区三区浴池| 国产日本欧美一区二区| 欧美在线短视频| 久久偷窥视频| 亚洲国产欧美一区二区三区同亚洲 | 国产亚洲人成a一在线v站| 午夜精品一区二区三区在线播放| 亚洲欧美国产77777| 国产欧美91| 久久嫩草精品久久久久| 亚洲成人在线免费| 欧美大片在线看| 艳妇臀荡乳欲伦亚洲一区| 亚洲一区高清| 国产偷久久久精品专区| 久久免费视频观看| 亚洲三级毛片| 欧美一区二区三区免费视频| 狠狠色丁香婷婷综合久久片| 久久精品亚洲热| 亚洲精品一区二区三区樱花| 亚洲欧美日韩专区| 伊人色综合久久天天五月婷| 欧美大片在线观看| 亚洲欧美国产精品桃花| 久久久久久综合网天天| 亚洲精品欧美一区二区三区| 国产精品国产a级| 久久久久国产一区二区三区四区| 亚洲国产欧美在线人成| 午夜视频久久久| 欧美视频一区在线观看| 免费视频亚洲| 在线午夜精品| 久久天天躁夜夜躁狠狠躁2022| 亚洲人永久免费| 国产精品手机在线| 欧美+日本+国产+在线a∨观看| 亚洲免费观看| 麻豆成人91精品二区三区| 亚洲午夜精品久久| 亚洲第一页在线| 国产精品爽爽ⅴa在线观看| 另类综合日韩欧美亚洲| 亚洲夜晚福利在线观看| 亚洲大片一区二区三区| 久久久久国产精品厨房| 亚洲一二三区在线观看| 亚洲欧洲中文日韩久久av乱码| 国产欧美精品日韩精品| 欧美日韩视频专区在线播放| 久久久久久久久久久久久久一区 | 欧美日韩精品欧美日韩精品| 久久精品视频网| 亚洲欧洲99久久| 99v久久综合狠狠综合久久| 欧美激情1区2区3区| 久久三级福利| 久久久久久999| 久久国产99| 午夜免费日韩视频| 亚洲欧美激情视频|