思路
想到的就是需要一个数组来记录是不是这行或者这列是不是有零,然后最后再扫描一遍这个矩阵
题解
借助第0行第0列来记录这个行是不是有0,这个列是不是有0
另外,这个矩阵不大,所以可能有重复的置0应该也没事。
class Solution {
public void setZeroes(int[][] matrix) {
boolean row_0 = false;
boolean column_0 = false;
int col = matrix[0].length; //这个是列
int row = matrix.length; //这个是行
for (int i = 0; i < col; i++) { //判断第一行有没有0值
if (matrix[0][i] == 0){ //第0行第i列
row_0 = true;
break;
}
}
for (int i = 0; i < row; i++) {//判断第一列有没有0值
if (matrix[i][0] == 0){
column_0 = true;
break;
}
}
for (int i = 1; i < col; i++) {
for (int j = 1; j < row; j++) {
if (matrix[j][i] == 0){
matrix[0][i] = 0; //列
matrix[j][0] = 0; //行
}
}
}
for (int i = 1; i < col; i++) { //列
if (matrix[0][i] == 0){
for (int j = 1; j < row; j++) {
matrix[j][i] = 0;
}
}
}
for (int i = 1; i < row; i++) { //行
if (matrix[i][0] == 0){
for (int j = 1; j < col; j++) {
matrix[i][j] = 0;
}
}
}
if (column_0 == true){ //处理第一列
for (int i = 0; i < row; i++) {
matrix[i][0] = 0;
}
}
if (row_0 == true){ //处理第一行
for (int i = 0; i < col; i++) { //不能处理0
matrix[0][i] = 0;
}
}
}
}