英文原文
Given an m x n
integer matrix matrix
, if an element is 0
, set its entire row and column to 0
's, and return the matrix.
You must do it in place.
Example 1:

Input: matrix = [[1,1,1],[1,0,1],[1,1,1]] Output: [[1,0,1],[0,0,0],[1,0,1]]
Example 2:

Input: matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]] Output: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]
Constraints:
m == matrix.length
n == matrix[0].length
1 <= m, n <= 200
-231 <= matrix[i][j] <= 231 - 1
Follow up:
- A straightforward solution using
O(mn)
space is probably a bad idea. - A simple improvement uses
O(m + n)
space, but still not the best solution. - Could you devise a constant space solution?
中文题目
给定一个 m x n
的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。
进阶:
- 一个直观的解决方案是使用
O(mn)
的额外空间,但这并不是一个好的解决方案。 - 一个简单的改进方案是使用
O(m + n)
的额外空间,但这仍然不是最好的解决方案。 - 你能想出一个仅使用常量空间的解决方案吗?
示例 1:

输入:matrix = [[1,1,1],[1,0,1],[1,1,1]] 输出:[[1,0,1],[0,0,0],[1,0,1]]
示例 2:

输入:matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]] 输出:[[0,0,0,0],[0,4,5,0],[0,3,1,0]]
提示:
m == matrix.length
n == matrix[0].length
1 <= m, n <= 200
-231 <= matrix[i][j] <= 231 - 1
通过代码
高赞题解
思路:
思路一: 用 $O(m+n)$额外空间
两遍扫matrix
,第一遍用集合记录哪些行,哪些列有0
;第二遍置0
思路二: 用$O(1)$空间
关键思想: 用matrix
第一行和第一列记录该行该列是否有0
,作为标志位
但是对于第一行,和第一列要设置一个标志位,为了防止自己这一行(一列)也有0
的情况.注释写在代码里,直接看代码很好理解!
代码:
思路一:
[1]class Solution: def setZeroes(self, matrix: List[List[int]]) -> None: """ Do not return anything, modify matrix in-place instead. """ row = len(matrix) col = len(matrix[0]) row_zero = set() col_zero = set() for i in range(row): for j in range(col): if matrix[i][j] == 0: row_zero.add(i) col_zero.add(j) for i in range(row): for j in range(col): if i in row_zero or j in col_zero: matrix[i][j] = 0
[1]class Solution { public void setZeroes(int[][] matrix) { Set<Integer> row_zero = new HashSet<>(); Set<Integer> col_zero = new HashSet<>(); int row = matrix.length; int col = matrix[0].length; for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { if (matrix[i][j] == 0) { row_zero.add(i); col_zero.add(j); } } } for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { if (row_zero.contains(i) || col_zero.contains(j)) matrix[i][j] = 0; } } } }
思路二:
[2]class Solution: def setZeroes(self, matrix: List[List[int]]) -> None: """ Do not return anything, modify matrix in-place instead. """ row = len(matrix) col = len(matrix[0]) row0_flag = False col0_flag = False # 找第一行是否有0 for j in range(col): if matrix[0][j] == 0: row0_flag = True break # 第一列是否有0 for i in range(row): if matrix[i][0] == 0: col0_flag = True break # 把第一行或者第一列作为 标志位 for i in range(1, row): for j in range(1, col): if matrix[i][j] == 0: matrix[i][0] = matrix[0][j] = 0 #print(matrix) # 置0 for i in range(1, row): for j in range(1, col): if matrix[i][0] == 0 or matrix[0][j] == 0: matrix[i][j] = 0 if row0_flag: for j in range(col): matrix[0][j] = 0 if col0_flag: for i in range(row): matrix[i][0] = 0
[2]class Solution { public void setZeroes(int[][] matrix) { int row = matrix.length; int col = matrix[0].length; boolean row0_flag = false; boolean col0_flag = false; // 第一行是否有零 for (int j = 0; j < col; j++) { if (matrix[0][j] == 0) { row0_flag = true; break; } } // 第一列是否有零 for (int i = 0; i < row; i++) { if (matrix[i][0] == 0) { col0_flag = true; break; } } // 把第一行第一列作为标志位 for (int i = 1; i < row; i++) { for (int j = 1; j < col; j++) { if (matrix[i][j] == 0) { matrix[i][0] = matrix[0][j] = 0; } } } // 置0 for (int i = 1; i < row; i++) { for (int j = 1; j < col; j++) { if (matrix[i][0] == 0 || matrix[0][j] == 0) { matrix[i][j] = 0; } } } if (row0_flag) { for (int j = 0; j < col; j++) { matrix[0][j] = 0; } } if (col0_flag) { for (int i = 0; i < row; i++) { matrix[i][0] = 0; } } } }
简化版
[3]class Solution: def setZeroes(self, matrix: List[List[int]]) -> None: """ Do not return anything, modify matrix in-place instead. """ flag_col = False row = len(matrix) col = len(matrix[0]) for i in range(row): if matrix[i][0] == 0: flag_col = True for j in range(1,col): if matrix[i][j] == 0: matrix[i][0] = matrix[0][j] = 0 for i in range(row - 1, -1, -1): for j in range(col - 1, 0, -1): if matrix[i][0] == 0 or matrix[0][j] == 0: matrix[i][j] = 0 if flag_col == True: matrix[i][0] = 0
[3]class Solution { public void setZeroes(int[][] matrix) { boolean col0_flag = false; int row = matrix.length; int col = matrix[0].length; for (int i = 0; i < row; i++) { if (matrix[i][0] == 0) col0_flag = true; for (int j = 1; j < col; j++) { if (matrix[i][j] == 0) { matrix[i][0] = matrix[0][j] = 0; } } } for (int i = row - 1; i >= 0; i--) { for (int j = col - 1; j >= 1; j--) { if (matrix[i][0] == 0 || matrix[0][j] == 0) { matrix[i][j] = 0; } } if (col0_flag) matrix[i][0] = 0; } } }
统计信息
通过次数 | 提交次数 | AC比率 |
---|---|---|
145695 | 239807 | 60.8% |
提交历史
提交时间 | 提交结果 | 执行时间 | 内存消耗 | 语言 |
---|
相似题目
题目 | 难度 |
---|---|
生命游戏 | 中等 |