• Leetcode73. Set Matrix Zeroes矩阵置零


    给定一个 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) 的额外空间,但这仍然不是最好的解决方案。
    • 你能想出一个常数空间的解决方案吗?

    方法一:

    class Solution {
    public:
        void setZeroes(vector<vector<int> >& matrix)
        {
            int r = matrix.size();
            if(r == 0)
                return;
            int c = matrix[0].size();
            vector<int> checkr(r, 0);
            vector<int> checkc(c ,0);
            for(int i = 0; i < r; i++)
                for(int j = 0; j < c; j++)
                if(matrix[i][j] == 0)
            {
                checkr[i] = 1;
                checkc[j] = 1;
            }
            for(int i = 0; i < r; i++)
            {
                if(checkr[i] == 0)
                    continue;
                for(int j = 0; j < c; j++)
                {
                    matrix[i][j] = 0;
                    if(checkc[j] == 0)
                        continue;
                    for(int k = 0; k < r; k++)
                        matrix[k][j] = 0;
                }
            }
        }
    };

    方法二:

    class Solution {
    public:
        void setZeroes(vector<vector<int> > &matrix) {
            if (matrix.empty() || matrix[0].empty()) return;
            int m = matrix.size(), n = matrix[0].size();
            bool rowZero = false, colZero = false;
            for (int i = 0; i < m; ++i) {
                if (matrix[i][0] == 0) colZero = true;
            }
            for (int i = 0; i < n; ++i) {
                if (matrix[0][i] == 0) rowZero = true;
            } 
            for (int i = 1; i < m; ++i) {
                for (int j = 1; j < n; ++j) {
                    if (matrix[i][j] == 0) {
                        matrix[0][j] = 0;
                        matrix[i][0] = 0;
                    }
                }
            }
            for (int i = 1; i < m; ++i) {
                for (int j = 1; j < n; ++j) {
                    if (matrix[0][j] == 0 || matrix[i][0] == 0) {
                        matrix[i][j] = 0;
                    }
                }
            }
            if (rowZero) {
                for (int i = 0; i < n; ++i) matrix[0][i] = 0;
            }
            if (colZero) {
                for (int i = 0; i < m; ++i) matrix[i][0] = 0;
            }
        }
    };
  • 相关阅读:
    hadoop大数据平台架构之DKhadoop详解
    越狱设备看不到系统文件夹
    iOS开发 调试 网络限速
    关于OCMock的一些事儿
    Cannot proceed with delivery: an existing transporter instance is currently uploading this package
    windows安装nose
    IE6支持png半透明图片
    ie下web常见错误和差异及解决方案
    js,php下 css颜色加深、减淡,css颜色递进的方法
    html+css div百分百占满正行的两种方法
  • 原文地址:https://www.cnblogs.com/lMonster81/p/10433861.html
Copyright © 2020-2023  润新知