加载中...
73-矩阵置零(Set Matrix Zeroes)
发表于:2021-12-03 | 分类: 中等
字数统计: 1.1k | 阅读时长: 5分钟 | 阅读量:

原文链接: https://leetcode-cn.com/problems/set-matrix-zeroes

英文原文

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%

提交历史

提交时间 提交结果 执行时间 内存消耗 语言

相似题目

题目 难度
生命游戏 中等
上一篇:
72-编辑距离(Edit Distance)
下一篇:
75-颜色分类(Sort Colors)
本文目录
本文目录