• <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
            給出一個2D迷宮(之字形編號),-1代表可以走的空格子,每次可以走[curr + 1, min(curr + 6, n2)]步,其中還有一些蛇形鏈接or梯子,如果走到這些格子則必須跳去蛇or梯子的終點,游戲終點是n*n號格子,問最快幾步可達,BFS


             1 #909
             2 #Runtime: 261 ms (Beats 11.90%)
             3 #Memory: 13.4 MB (Beats 92.86%)
             4 
             5 class Solution(object):
             6     def snakesAndLadders(self, board):
             7         """
             8         :type board: List[List[int]]
             9         :rtype: int
            10         """
            11         vis = set([1])
            12         n = len(board)
            13         board_linear = []
            14         for i in range(n-1, -1, -1):
            15             if i%2 != n%2:
            16                 for j in range(n):
            17                     board_linear.append(board[i][j])
            18             else:
            19                 for j in range(n-1, -1, -1):
            20                     board_linear.append(board[i][j])      
            21         q = deque([(1, 0)])
            22         while q:
            23             x = q.popleft()
            24             for i in range(6):
            25                 if x[0] + i > n*n:
            26                     break
            27                 if board_linear[x[0] + i] == -1:
            28                     tx = x[0] + i + 1
            29                 else:
            30                     tx = board_linear[x[0] + i]
            31                 if tx == n*n:
            32                     return x[1] + 1
            33                 if tx in vis:
            34                     continue
            35                 vis.add(tx)
            36                 q.append((tx, x[1] + 1))
            37         return -1
            久久久久人妻一区精品果冻| 亚洲精品国产综合久久一线| 午夜不卡久久精品无码免费| 日本强好片久久久久久AAA| AAA级久久久精品无码片| 国产精品美女久久久免费| 无夜精品久久久久久| 91精品国产91久久综合| 热综合一本伊人久久精品| 九九精品99久久久香蕉| 亚洲精品国产综合久久一线| 久久精品欧美日韩精品| 久久久精品日本一区二区三区| 国产69精品久久久久观看软件 | 久久99热国产这有精品| 国产真实乱对白精彩久久| 色欲久久久天天天综合网| 久久强奷乱码老熟女网站| 99精品久久久久中文字幕| 三级三级久久三级久久| 国产精品久久久天天影视香蕉| 日韩精品久久久久久久电影蜜臀| 久久久久亚洲精品天堂久久久久久 | 久久精品国产免费观看| 国产一区二区精品久久凹凸| 91久久精一区二区三区大全| 久久午夜免费视频| 亚洲七七久久精品中文国产| 99国内精品久久久久久久| 国内精品九九久久久精品| 久久久久久午夜成人影院| 亚洲精品乱码久久久久久中文字幕| 久久精品成人一区二区三区| 狠狠色丁香婷婷综合久久来来去| 国产精品久久久久影视不卡| 97久久久久人妻精品专区| 丁香狠狠色婷婷久久综合| 久久精品www人人爽人人| 久久99精品久久久久久hb无码| 久久人妻少妇嫩草AV无码专区| 久久亚洲欧美国产精品|