β Set Matrix Zeros
void Solution::setZeroes(vector<vector<int> > &A) {
// storage to remember which rows and cols will be zeroed.
vector<bool> zeroRow(A.size());
vector<bool> zeroCol(A[0].size());
// storing rows and cols that need to be zeroed without modifying the array
for(int i = 0; i < A.size(); i++)
for(int j = 0; j < A[0].size(); j++)
if(A[i][j] == 0)
zeroRow[i] = zeroCol[j] = true;
// using zeroRow and zeroCol to actaully mark each element
for(int i = 0; i < A.size(); i++)
for(int j = 0; j < A[0].size(); j++)
if(zeroRow[i] || zeroCol[j])
A[i][j] = 0;
}
Time Complexity: β
Space Complexity:
Last updated