ToB企服应用市场:ToB评测及商务社交产业平台

标题: LeetCode 热题 100 73. 矩阵置零 [打印本页]

作者: 商道如狼道    时间: 5 天前
标题: LeetCode 热题 100 73. 矩阵置零
LeetCode 热题 100 | 73. 矩阵置零

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

问题形貌

给定一个 m x n 的矩阵,假如一个元素为 0,则将其所在行和列的所有元素都设为 0。
示例:
  1. 输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
  2. 输出:[[1,0,1],[0,0,0],[1,0,1]]
复制代码

非原地算法代码

思绪

代码实现

  1. def setZeroes_non_inplace(matrix):
  2.     m, n = len(matrix), len(matrix[0])
  3.     rows = [False] * m  # 记录需要置零的行
  4.     cols = [False] * n  # 记录需要置零的列
  5.     # 遍历矩阵,记录需要置零的行和列
  6.     for i in range(m):
  7.         for j in range(n):
  8.             if matrix[i][j] == 0:
  9.                 rows[i] = True
  10.                 cols[j] = True
  11.     # 根据记录置零
  12.     for i in range(m):
  13.         for j in range(n):
  14.             if rows[i] or cols[j]:
  15.                 matrix[i][j] = 0
  16. # 测试示例
  17. matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
  18. matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
  19. setZeroes_non_inplace(matrix1)
  20. setZeroes_non_inplace(matrix2)
  21. print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
  22. print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]
复制代码

原地算法代码

思绪

代码实现

  1. def setZeroes_inplace(matrix):
  2.     m, n = len(matrix), len(matrix[0])
  3.     first_row_has_zero = any(matrix[0][j] == 0 for j in range(n))
  4.     first_col_has_zero = any(matrix[i][0] == 0 for i in range(m))
  5.     # 使用第一行和第一列来标记是否需要置零
  6.     for i in range(1, m):
  7.         for j in range(1, n):
  8.             if matrix[i][j] == 0:
  9.                 matrix[i][0] = 0
  10.                 matrix[0][j] = 0
  11.     # 根据标记置零
  12.     for i in range(1, m):
  13.         for j in range(1, n):
  14.             if matrix[i][0] == 0 or matrix[0][j] == 0:
  15.                 matrix[i][j] = 0
  16.     # 处理第一行和第一列
  17.     if first_row_has_zero:
  18.         for j in range(n):
  19.             matrix[0][j] = 0
  20.     if first_col_has_zero:
  21.         for i in range(m):
  22.             matrix[i][0] = 0
  23. # 测试示例
  24. matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
  25. matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
  26. setZeroes_inplace(matrix1)
  27. setZeroes_inplace(matrix2)
  28. print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
  29. print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]
复制代码

代码对比

非原地算法


原地算法



总结


根据实际需求选择合适的方法即可。希望这篇题解对大家有所资助,假如有任何问题,欢迎在评论区留言讨论!
关注我,获取更多算法题解和编程技巧!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4