Solution: Set Matrix Zeroes
Let's solve the Set Matrix Zeroes problem using the Matrix Transformations pattern.
Statement
Given a matrix, mat
, if any element within the matrix is zero, set that row and column to zero.
Constraints:
-
mat.row
,mat.col
-
mat[i][j]
Solution
So far, you’ve probably brainstormed some approaches and have an idea of how to solve this problem. Let’s explore some of these approaches and figure out which one to follow based on considerations such as time complexity and any implementation constraints.
Naive approach
The naive approach to solve this problem is by taking an extra matrix, mat2
. First, copy all the elements of the given mat
to mat2
. Then, while traversing mat
, whenever we encounter 0
, we will make the entire row and column of the mat2
to 0
. In the end, again, copy all the elements of mat2
to mat
. This solution has high time and space complexity, which is and , respectively. Let’s see the optimized approach.
Optimized approach using the matrices pattern
The key idea behind this algorithm is to use the matrix’s first row and column as storage space to track which rows and columns need to be zeroed, thus eliminating the need for additional data structures. The corresponding positions in the first row and column are marked when a zero is found. These markers then set the entire row or column to zero in a second pass through the matrix. Using this approach, the algorithm modifies the matrix with minimal extra space required.
Now, let’s look at the workflow of the implementation:
The first step is to get the number of rows and columns of the mat
. Then we set two boolean flags, fcol
and frow
, to indicate any presence of 0
in the first row and first column, respectively, and set both flags to FALSE. Now, we check the first column and first row and set the frow
and fcol
to TRUE if we find any 0
in the first row and the first column, respectively. This is because at this stage, we will not set the entire first row or column to 0
as it can make the following rows and columns 0
.
Now, we check all the elements row-wise (by ignoring the first row and first column), and if a 0
is found, we set the first element in that row and column to 0
. Now, we set 0
in rows and columns where required by following rules:
- Check every row’s first element, starting from the second row, and if it is
0
, set all values in that row to0
. - Check every column’s first element, starting from the second column, and if it is
0
, set all values in that row to0
.
Now, we check the first row and first column. If the values of frow
and fcol
are TRUE, it indicates any 0
in the first row and first column, respectively. We will set 0
in the corresponding row and column.
In the end, we return the mat
.
Let’s look at the following illustration to get a better understanding of the solution:
Let’s have a look at the code for the algorithm we just discussed.
import java.util.*;class Solution {public static int[][] setMatrixZeros(int[][] mat) {int rows = mat.length;int cols = mat[0].length;boolean fcol = false;boolean frow = false;for (int i = 0; i < rows; i++) {if (mat[i][0] == 0) {fcol = true;break;}}for (int i = 0; i < cols; i++) {if (mat[0][i] == 0) {frow = true;break;}}for (int i = 1; i < rows; i++) {for (int j = 1; j < cols; j++) {if (mat[i][j] == 0) {mat[0][j] = 0;mat[i][0] = 0;}}}for (int i = 1; i < rows; i++) {if (mat[i][0] == 0) {Arrays.fill(mat[i], 0);}}for (int j = 1; j < cols; j++) {if (mat[0][j] == 0) {for (int i = 1; i < rows; i++) {mat[i][j] = 0;}}}if (fcol) {for (int i = 0; i < rows; i++) {mat[i][0] = 0;}}if (frow) {Arrays.fill(mat[0], 0);}return mat;}// Driver codepublic static void main(String[] args) {int[][][] mat = {{{1, 1, 0}, {1, 0, 1}, {1, 1, 1}},{{1, 1, 1, 1, 1}, {0, 0, 1, 1, 1}, {1, 1, 1, 1, 0}, {1, 1, 1, 1, 1}},{{3, 5, 2, 0}, {1, 0, 4, 6}, {7, 3, 2, 4}},{{1, 2, 3, 4}, {4, 5, 6, 7}, {8, 9, 4, 6}},{{2, 6, 5, 4, 9, 1}, {7, 2, 0, 0, 5, 4}, {1, 1, 1, 1, 0, 1}, {9, 8, 2, 0, 1, 3}, {7, 8, 6, 5, 4, 3}, {9, 8, 1, 2, 5, 6}}};for (int i = 0; i < mat.length; i++) {System.out.println((i + 1) + ". \tOriginal Matrix:");Print.printMatrix(mat[i]);int[][] result = setMatrixZeros(mat[i]);System.out.println("\n\tMatrix with Zeroes:");Print.printMatrix(result);System.out.println(new String(new char[100]).replace('\0', '-'));}}}
Solution summary
- Calculate the number of rows and columns of the
mat
. - Set
fcol
andfrow
to FALSE. - Check the first column and first row. If any element from the first row or first column is
0
, setfrow
orfcol
to TRUE, respectively. - Check all the elements row-wise by ignoring the first row and first column. If a
0
is found, we set the first element in that row and column to0
. - Check every row’s first element, starting from the second row, and if it is
0
, set all values in that row to0
. - Check every column’s first element, starting from the second column, and if it’s
0
, set all values in that row to0
. - If
frow
is TRUE, set0
in the first row. - If
fcol
is TRUE, set0
in the first column. - Return
mat
.
Time complexity
The time complexity of this algorithm is , where and are the dimensions of the matrix.
Space complexity
The space complexity is because we use no extra memory.
Level up your interview prep. Join Educative to access 70+ hands-on prep courses.