欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 会展 > LeetCode 热题 100 73. 矩阵置零

LeetCode 热题 100 73. 矩阵置零

2025/2/23 13:53:28 来源:https://blog.csdn.net/m0_63951116/article/details/145774369  浏览:    关键词:LeetCode 热题 100 73. 矩阵置零

LeetCode 热题 100 | 73. 矩阵置零

大家好,今天我们来解决一道经典的算法题——矩阵置零。这道题在LeetCode上被标记为中等难度,要求我们将矩阵中为0的元素所在的行和列全部置为0。下面我将分别给出非原地算法原地算法的Python代码实现,并进行对比分析。


问题描述

给定一个 m x n 的矩阵,如果一个元素为 0,则将其所在行和列的所有元素都设为 0

示例:

输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]

非原地算法代码

思路
  1. 使用两个额外的数组 rowscols 来记录需要置零的行和列。
  2. 遍历矩阵,记录所有值为 0 的元素所在的行和列。
  3. 根据记录的行和列,将矩阵中对应的行和列全部置为 0
代码实现
def setZeroes_non_inplace(matrix):m, n = len(matrix), len(matrix[0])rows = [False] * m  # 记录需要置零的行cols = [False] * n  # 记录需要置零的列# 遍历矩阵,记录需要置零的行和列for i in range(m):for j in range(n):if matrix[i][j] == 0:rows[i] = Truecols[j] = True# 根据记录置零for i in range(m):for j in range(n):if rows[i] or cols[j]:matrix[i][j] = 0# 测试示例
matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]setZeroes_non_inplace(matrix1)
setZeroes_non_inplace(matrix2)print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]

原地算法代码

思路
  1. 利用矩阵的第一行和第一列来标记需要置零的行和列。
  2. 需要额外处理第一行和第一列本身是否包含 0
代码实现
def setZeroes_inplace(matrix):m, n = len(matrix), len(matrix[0])first_row_has_zero = any(matrix[0][j] == 0 for j in range(n))first_col_has_zero = any(matrix[i][0] == 0 for i in range(m))# 使用第一行和第一列来标记是否需要置零for i in range(1, m):for j in range(1, n):if matrix[i][j] == 0:matrix[i][0] = 0matrix[0][j] = 0# 根据标记置零for i in range(1, m):for j in range(1, n):if matrix[i][0] == 0 or matrix[0][j] == 0:matrix[i][j] = 0# 处理第一行和第一列if first_row_has_zero:for j in range(n):matrix[0][j] = 0if first_col_has_zero:for i in range(m):matrix[i][0] = 0# 测试示例
matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]setZeroes_inplace(matrix1)
setZeroes_inplace(matrix2)print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]

代码对比

非原地算法
  • 优点
    • 逻辑简单,易于理解和实现。
    • 不需要修改原始矩阵的额外信息。
  • 缺点
    • 使用了额外的空间 O(m + n) 来存储需要置零的行和列。
原地算法
  • 优点
    • 空间复杂度为 O(1),完全原地操作。
  • 缺点
    • 逻辑稍复杂,需要额外处理第一行和第一列。

总结

  • 非原地算法:逻辑简单,适合对空间复杂度要求不高的场景。
  • 原地算法:空间复杂度低,适合对空间要求严格的场景。

根据实际需求选择合适的方法即可。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词