给定一个 m x n 的矩阵,如果一个元素为 0,则将其所在行和列的所有元素都设为 0。请使用原地算法。
示例 1:
输入:
[
[1,1,1],
[1,0,1],
[1,1,1]
]
输出:
[
[1,0,1],
[0,0,0],
[1,0,1]
]
示例 2:
输入:
[
[0,1,2,0],
[3,4,5,2],
[1,3,1,5]
]
输出:
[
[0,0,0,0],
[0,4,5,0],
[0,3,1,0]
]
进阶:
一个直接的解决方案是使用 O(mn) 的额外空间,但这并不是一个好的解决方案。
一个简单的改进方案是使用 O(m + n) 的额外空间,但这仍然不是最好的解决方案。
你能想出一个常数空间的解决方案吗?
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/set-matrix-zeroes
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法:如果要原地算法的话就遍历两遍,第一遍对需要做修改的值做标记,第二遍最标记的值修改成0,标记的值取一个特殊值,但是并不知道应该取多少,这里取-10000成功了
解法:如果可以使用额外空间,可以采用set来保存需要修改的行和列,然后对做好标记的行列进行修改
class Solution {
public:
void setZeroes(vector<vector<int>>& matrix) {
//使用set来保存需要修改的行和列
set<int> hang,lie;
int m = matrix.size(),n = matrix[0].size();
//扫描一遍获取为0的元素行列
for(int i=0;i<m;i++){
for(int j=0;j<n;j++){
if(matrix[i][j] == 0){
hang.insert(i);
lie.insert(j);
}
}
}
//对于行列分别进行赋值
for(auto &h:hang){
for(int j=0;j<n;j++){
matrix[h][j] = 0;
}
}
for(auto &l:lie){
for(int i=0;i<m;i++){
matrix[i][l] = 0;
}
}
}
void setZeroes1(vector<vector<int>>& matrix) {
//遍历两次,第一次做一些标记,第二次根据标记做修改
/*
1 -> 0 : -100000 因此元素等于-1表示后面要变成0
0 -> 0 : 0
*/
int m = matrix.size(),n = matrix[0].size();
for(int i = 0;i < m;i++){
for(int j = 0;j < n;j++){
if(matrix[i][j] != 0)
continue;
//如果是0则需要修改行列
changeMatrix(i,j,matrix);
}
}
for(int i = 0;i < m;i++){
for(int j = 0;j < n;j++){
if(matrix[i][j] == -100000)
matrix[i][j] = 0;
}
}
}
void changeMatrix(int x,int y,vector<vector<int>>& matrix){
//根据0元素的下标,修改行列元素的值
int m = matrix.size(),n = matrix[0].size();
int i = 0,j = 0;
//对列上的元素进行修改
while(i < m){
if(matrix[i][y] != 0){
//只有等于1的需要被修改成0,但是暂时被标记为2
matrix[i][y] = -100000;
}
++i;
}
//对行上元素进行修改
while(j < n){
if(matrix[x][j] != 0){
matrix[x][j] = -100000;
}
++j;
}
}
};