算法刷题 -- 73. 矩阵置零<难度 ★★☆>
1、
-
思路:
- 标记数组,行和列为0的位置
- 然后再统一根据为0的行和列,将对应的行和列数字置零
class Solution { public void setZeroes(int[][] matrix) { int m = matrix.length; int n = matrix[0].length; int[] row = new int[m]; int[] col = new int[n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (matrix[i][j] != 0) { continue; } row[i] = 1; // 做标记 col[j] = 1; // 标记 } } for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (row[i] == 1) { // 根据标记置零 matrix[i][j] = 0; } if (col[j] == 1) { // 根据标记置零 matrix[i][j] = 0; } } } } }
上一篇:
通过多线程提高代码的执行效率例子
下一篇:
跳槽一次能涨多少?今天见识到跳槽天花板。