• <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
            給出一堆樹的坐標(biāo),用最小的多邊形圍住這些樹,求問最后哪些樹在多邊形的頂點(diǎn)上,凸包模板題
            借鑒了https://leetcode.com/problems/erect-the-fence/discuss/1442266/A-Detailed-Explanation-with-Diagrams-(Graham-Scan) 的做法,先對(duì)樹坐標(biāo)先x后y排序,在分上下半塊凸包分別構(gòu)建

             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))
            国产午夜福利精品久久| 久久久久噜噜噜亚洲熟女综合| 亚洲日本va午夜中文字幕久久 | 青青青国产成人久久111网站| 女人高潮久久久叫人喷水| 欧美日韩精品久久久免费观看| 久久人人超碰精品CAOPOREN| 激情久久久久久久久久| 伊人色综合久久天天网| 久久久久亚洲精品日久生情| 精品无码久久久久国产动漫3d| 熟妇人妻久久中文字幕| 丰满少妇人妻久久久久久| 久久久国产精品网站| 国产精品成人久久久久久久| 国产亚洲色婷婷久久99精品91| 久久亚洲国产精品五月天婷| 久久精品国产亚洲av麻豆图片 | 久久国产AVJUST麻豆| 欧美亚洲色综久久精品国产| 国产国产成人精品久久| 久久se精品一区精品二区国产| 亚洲第一永久AV网站久久精品男人的天堂AV| 欧美午夜精品久久久久久浪潮| 欧美伊人久久大香线蕉综合| 国产精品久久久久久久| 精品999久久久久久中文字幕| 97精品国产97久久久久久免费| 日本久久久久久久久久| 亚洲国产精品无码久久久蜜芽| 国产精品久久久福利| 亚洲性久久久影院| 久久综合综合久久狠狠狠97色88 | 国产成人精品综合久久久| 国产精品亚洲综合久久| 久久综合九色综合久99| 久久久久高潮综合影院| 久久久99精品成人片中文字幕| 久久婷婷国产综合精品| 久久婷婷色综合一区二区| 草草久久久无码国产专区|