• <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>

            Uriel's Corner

            Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
            posts - 0, comments - 50, trackbacks - 0, articles - 594
            給出一堆樹的坐標,用最小的多邊形圍住這些樹,求問最后哪些樹在多邊形的頂點上,凸包模板題
            借鑒了https://leetcode.com/problems/erect-the-fence/discuss/1442266/A-Detailed-Explanation-with-Diagrams-(Graham-Scan) 的做法,先對樹坐標先x后y排序,在分上下半塊凸包分別構建

             1 #587
             2 #Runtime: 562 ms
             3 #Memory Usage: 14.2 MB
             4 
             5 class Solution(object):
             6     def corssProduct(self, p1, p2, p3):
             7         return (p3[1]-p2[1]) * (p2[0]-p1[0]) - (p2[1]-p1[1]) * (p3[0]-p2[0])
             8     
             9     def buildConvexHull(self, points):
            10         lower = []
            11         upper = []
            12         for pt in points:
            13             while len(lower) >= 2 and self.corssProduct(lower[-2], lower[-1], pt) < 0:
            14                 lower.pop()
            15             while len(upper) >= 2 and self.corssProduct(upper[-2], upper[-1], pt) > 0:
            16                 upper.pop()
            17             upper.append(pt)
            18             lower.append(pt)
            19         return upper, lower
            20         
            21     def outerTrees(self, trees):
            22         
            23         """
            24         :type trees: List[List[int]]
            25         :rtype: List[List[int]]
            26         """
            27         points = sorted(trees)
            28         upper, lower = self.buildConvexHull(points)
            29         return set(tuple(T) for T in (upper + lower))
            99国内精品久久久久久久| 女同久久| 久久精品亚洲日本波多野结衣 | 国产成年无码久久久免费| 久久精品国产亚洲AV麻豆网站| 久久精品国产亚洲欧美| 色妞色综合久久夜夜| yellow中文字幕久久网| 色妞色综合久久夜夜| 国产精品激情综合久久| 久久精品卫校国产小美女| 久久久久一区二区三区| 国产69精品久久久久9999APGF| 一级做a爰片久久毛片16| 久久精品国产AV一区二区三区| 久久精品国产精品亚洲| 97久久精品国产精品青草| 久久久久久伊人高潮影院| 久久久久国产一级毛片高清板| 国产精品久久一区二区三区 | 精品久久久久久久无码| 精品久久亚洲中文无码| 国产精品久久久久久久app| 中文字幕亚洲综合久久2| 国产精品九九九久久九九| 久久天堂AV综合合色蜜桃网 | 婷婷五月深深久久精品| 国产精品一区二区久久精品涩爱| 精品国产乱码久久久久软件| 99久久99久久精品国产片| 亚洲人成无码www久久久| 久久久久久免费视频| 国产激情久久久久影院老熟女免费| 久久精品人人做人人妻人人玩| 亚洲中文字幕无码久久2017| 囯产极品美女高潮无套久久久| 成人午夜精品无码区久久| 国内精品伊人久久久影院| 久久精品中文字幕大胸| 亚洲伊人久久精品影院| 国产精品久久久久久|