Python | Leetcode Python题解之第542题01矩阵

题目:

题解:

python 复制代码
class Solution:
    def updateMatrix(self, matrix: List[List[int]]) -> List[List[int]]:
        m, n = len(matrix), len(matrix[0])
        # 初始化动态规划的数组,所有的距离值都设置为一个很大的数
        dist = [[10**9] * n for _ in range(m)]
        # 如果 (i, j) 的元素为 0,那么距离为 0
        for i in range(m):
            for j in range(n):
                if matrix[i][j] == 0:
                    dist[i][j] = 0
        # 只有 水平向左移动 和 竖直向上移动,注意动态规划的计算顺序
        for i in range(m):
            for j in range(n):
                if i - 1 >= 0:
                    dist[i][j] = min(dist[i][j], dist[i - 1][j] + 1)
                if j - 1 >= 0:
                    dist[i][j] = min(dist[i][j], dist[i][j - 1] + 1)
        # 只有 水平向左移动 和 竖直向下移动,注意动态规划的计算顺序
        for i in range(m - 1, -1, -1):
            for j in range(n):
                if i + 1 < m:
                    dist[i][j] = min(dist[i][j], dist[i + 1][j] + 1)
                if j - 1 >= 0:
                    dist[i][j] = min(dist[i][j], dist[i][j - 1] + 1)
        # 只有 水平向右移动 和 竖直向上移动,注意动态规划的计算顺序
        for i in range(m):
            for j in range(n - 1, -1, -1):
                if i - 1 >= 0:
                    dist[i][j] = min(dist[i][j], dist[i - 1][j] + 1)
                if j + 1 < n:
                    dist[i][j] = min(dist[i][j], dist[i][j + 1] + 1)
        # 只有 水平向右移动 和 竖直向下移动,注意动态规划的计算顺序
        for i in range(m - 1, -1, -1):
            for j in range(n - 1, -1, -1):
                if i + 1 < m:
                    dist[i][j] = min(dist[i][j], dist[i + 1][j] + 1)
                if j + 1 < n:
                    dist[i][j] = min(dist[i][j], dist[i][j + 1] + 1)
        return dist
相关推荐
Wyz20121024几秒前
Golang interface底层实现原理_Golang接口原理教程【核心】
jvm·数据库·python
qq_372154231 分钟前
宝塔面板如何快速找回前一天误删的极其重要的网站源码
jvm·数据库·python
Shorasul1 分钟前
Vue3 监听器 watch 怎么监听 Pinia 中的状态?跨模块联动开发教程
jvm·数据库·python
m0_734949792 分钟前
JavaScript 中的 setTimeout 是否依赖系统时钟?
jvm·数据库·python
2301_817672263 分钟前
Python Selenium怎么定位元素_By.XPATH与By.CSS_SELECTOR操作DOM节点
jvm·数据库·python
2501_914245933 分钟前
JavaScript中闭包结合代理模式Proxy实现数据监听
jvm·数据库·python
m0_493934535 分钟前
WordPress 动态变量短代码:基于用户输入自动匹配预设值的高效实现
jvm·数据库·python
weixin_408717778 分钟前
mysql在新闻网站中的文章和评论数据库设计
jvm·数据库·python
weixin_5689960611 分钟前
如何利用宝塔面板快速部署Node.js项目_配置PM2守护进程
jvm·数据库·python
weixin_5860614613 分钟前
mysql如何处理表空间碎片问题_执行OPTIMIZE TABLE整理
jvm·数据库·python