• <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
             一個row行col列的二維矩陣,初始所有元素為0,代表均可以走,每天有一個格子變為1,不可走,問最遲第幾天可以依舊從第一行走到最后一行(具體從第幾列開始,走向第幾列無要求),可以四個方向走
            二分答案+DFS確認是否可達


             1 #1970
             2 #Runtime: 3361 ms (Beats 85.71%)
             3 #Memory: 39.9 MB (Beats 14.29%)
             4 
             5 class Solution(object):
             6     def latestDayToCross(self, row, col, cells):
             7         """
             8         :type row: int
             9         :type col: int
            10         :type cells: List[List[int]]
            11         :rtype: int
            12         """
            13         d = [[0, 1], [0, -1], [-1, 0], [1, 0]]
            14         def DFS(grid, r, c):
            15             if 0 <= r < row and 0 <= c < col and grid[r][c] == 0:
            16                 if r == row - 1:
            17                     return True
            18                 grid[r][c] = -1
            19                 for x in d:
            20                     tr = r + x[0]
            21                     tc = c + x[1]
            22                     if DFS(grid, tr, tc):
            23                         return True
            24             return False
            25 
            26         def ok(x):
            27             grid = [[0] * col for _ in range(row)]
            28             for i in range(x):
            29                 grid[cells[i][0] - 1][cells[i][1] - 1] = 1
            30             for i in range(col):
            31                 if grid[0][i] == 0 and DFS(grid, 0, i):
            32                     return True
            33             return False
            34 
            35         l = 1
            36         r = len(cells)
            37         while l < r:           
            38             mid = (l + r) // 2 + (l + r) % 2
            39             if ok(mid):
            40                 l = mid
            41             else:
            42                 r = mid - 1
            43         return l
            44 
            久久精品国产亚洲Aⅴ蜜臀色欲| 一本久道久久综合狠狠躁AV| 久久精品国产亚洲AV高清热 | 国产精品福利一区二区久久| 欧美激情精品久久久久| 国产三级观看久久| 伊人久久大香线蕉综合影院首页 | 99久久精品国产一区二区三区| 国内精品伊人久久久久影院对白| 久久99这里只有精品国产| 精品免费久久久久久久| 四虎久久影院| 亚洲国产成人久久综合碰碰动漫3d| 亚洲七七久久精品中文国产| 久久ww精品w免费人成| 久久影院久久香蕉国产线看观看| 久久亚洲精品无码AV红樱桃| 久久综合九色综合久99| 亚洲国产精品婷婷久久| 久久久久久久亚洲Av无码| 伊人久久国产免费观看视频| 国产女人aaa级久久久级| 国产Av激情久久无码天堂 | 色成年激情久久综合| 亚洲综合伊人久久大杳蕉| 无码任你躁久久久久久| 91精品国产综合久久香蕉| 久久久久亚洲AV无码麻豆| 亚洲精品tv久久久久久久久| 欧美精品国产综合久久| 国产欧美久久久精品影院| 香蕉99久久国产综合精品宅男自 | 久久香综合精品久久伊人| 一本大道久久a久久精品综合| 精品国产乱码久久久久久人妻| 久久强奷乱码老熟女网站| 国产成人精品久久| 久久99热这里只有精品国产| 91亚洲国产成人久久精品| 激情五月综合综合久久69| 久久精品国产一区二区电影|