LeetCode#73. 矩阵置零

给定一个 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;
        }
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值