代码拉取完成,页面将自动刷新
# Time: O(n^2)
# Space: O(n^2)
import collections
class Solution(object):
def snakesAndLadders(self, board):
"""
:type board: List[List[int]]
:rtype: int
"""
def coordinate(n, s):
a, b = divmod(s-1, n)
r = n-1-a
c = b if r%2 != n%2 else n-1-b
return r, c
n = len(board)
lookup = {1: 0}
q = collections.deque([1])
while q:
s = q.popleft()
if s == n*n:
return lookup[s]
for s2 in xrange(s+1, min(s+6, n*n)+1):
r, c = coordinate(n, s2)
if board[r][c] != -1:
s2 = board[r][c]
if s2 not in lookup:
lookup[s2] = lookup[s]+1
q.append(s2)
return -1
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。