• <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>
            隨筆-80  評(píng)論-24  文章-0  trackbacks-0
            問題一:求N個(gè)點(diǎn)中斜率最大的兩個(gè)點(diǎn)。
            要解決該問題,我們首先證明一個(gè)結(jié)論:三個(gè)點(diǎn)a、b、c,若xa < xb < xc則斜率最大者必定是ab或者是bc,而不會(huì)是ac。證明如下:
            我們用k表示斜率,
            不妨假設(shè)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
            證畢。
            有了上面的證明,我們就可以先對(duì)N個(gè)點(diǎn)的橫坐標(biāo)排序,然后再計(jì)算a[i]與a[i + 1]的斜率,取最大值即可。
            代碼略。

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



            然后是判斷P2是否應(yīng)該入棧:



            因?yàn)镻0P1 X P0P2 > 0,所以P2入棧:



            然后判斷P3是否應(yīng)該入棧:



            因?yàn)镻1P2 X P1P3 < 0,所以P2出棧P3入棧:



            判斷P4是否應(yīng)該入棧:



            因?yàn)镻1P3 X P1P4 > 0,所以P4入棧:



            判斷P5是否應(yīng)該入棧:



            因?yàn)镻3P4 X P3P5 > 0,所以P5入棧:



            判斷P6是否應(yīng)該入棧:



            因?yàn)镻4P5 X P4P6 < 0,所以p5出棧P6入棧:



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



            通過以上圖示過程可以清晰明白凸包的構(gòu)建過程。證明過程比較復(fù)雜,詳見《算法導(dǎo)論》。
            posted on 2012-09-07 12:56 myjfm 閱讀(565) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
            亚洲国产精品久久久久婷婷软件| 精品无码久久久久国产| 久久无码一区二区三区少妇| 久久精品国产亚洲一区二区三区| 久久人人爽人爽人人爽av| 久久精品国产AV一区二区三区| 久久99国产综合精品女同| 国产精品成人无码久久久久久| 2021国内精品久久久久久影院| 亚洲中文字幕无码久久精品1| 久久久久久狠狠丁香| 国产A级毛片久久久精品毛片| 久久99久久99小草精品免视看| 亚洲国产精品狼友中文久久久 | 97久久精品国产精品青草| 国产激情久久久久影院老熟女| 久久久无码精品亚洲日韩京东传媒| 久久精品www人人爽人人| 四虎影视久久久免费观看| 久久精品国产亚洲综合色| 亚洲香蕉网久久综合影视| 久久影视国产亚洲| 国产成人精品久久一区二区三区av | 久久e热在这里只有国产中文精品99 | 精品久久久噜噜噜久久久| 久久亚洲精品成人无码网站| 国产精品gz久久久| 精品国产一区二区三区久久| 东方aⅴ免费观看久久av| 性做久久久久久久久浪潮| 日韩一区二区三区视频久久| 久久夜色tv网站| 77777亚洲午夜久久多喷| 无码人妻精品一区二区三区久久久| 伊色综合久久之综合久久| 久久综合亚洲色HEZYO国产| 国产香蕉97碰碰久久人人| 精品久久久久中文字幕一区| 久久www免费人成精品香蕉| 久久久久一级精品亚洲国产成人综合AV区 | 99久久99久久精品国产片果冻|