zoukankan      html  css  js  c++  java
  • LeetCode:Set Matrix Zeroes

    题目链接

    Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place.

    Follow up:

    Did you use extra space?
    A straight forward solution using O(mn) space is probably a bad idea.
    A simple improvement uses O(m + n) space, but still not the best solution.
    Could you devise a constant space solution?                                            本文地址

    分析:O(mn)解法:用m*n的空间记录每个某个位置是否要设置成0。O(m+n)解法:用一个数组记录某一列是否需要设置成0,用一个数组记录某一行是否需要设置成0。常数空间呢?如果我们可以用matrix本身的空间来记录,就不需要额外的空间了。解法如下:

    用matrix第一行记录相应的列是都需要置0,第一列来记录相应的行是否需要置0。用来记录之前需要提前判断第一行和第一列是否需要置0。然后遍历matrix(出了第一行和第一列)如果matrix[i][j]等于0,那么matrixp[i][0] = 0 (行标志),matrix[0][j] = 0(列标志)。再次遍历matrix只要对应位置的行标志或者列标志等于0,相应的位置就置0,。最后还要看第一行和第一列是否需要置0.

    class Solution {
    public:
        void setZeroes(vector<vector<int> > &matrix) {
            //使用第一行和第一列作为记录空间
            int row = matrix.size();
            if(row == 0)return;
            int col = matrix[0].size();
            bool firstRow = false, firstCol = false;//第一行和第一列是否要清0的标志
            for(int i = 0; i < col; i++)
                if(matrix[0][i] == 0){firstRow = true; break;}
            for(int i = 0; i < row; i++)
                if(matrix[i][0] == 0){firstCol = true; break;}
                
            for(int i = 1; i < row; i++)
                for(int j = 1; j < col; j++)
                    if(matrix[i][j] == 0)
                    {
                        matrix[i][0] = 0;
                        matrix[0][j] = 0;
                    }
            for(int i = 1; i < row; i++)
                for(int j = 1; j < col; j++)
                    if(matrix[i][0] == 0 || matrix[0][j] == 0)
                        matrix[i][j] = 0;
                        
            if(firstRow)
                for(int i = 0; i < col; i++)
                    matrix[0][i] = 0;
            if(firstCol)
                for(int i = 0; i < row; i++)
                    matrix[i][0] = 0;
        }
    };

    【版权声明】转载请注明出处http://www.cnblogs.com/TenosDoIt/p/3465273.html

  • 相关阅读:
    SQL所有者更改问题
    人生路上对我影响最大的三位老师
    自我介绍
    Ural_1146. Maximum Sum (DP)
    Ural_1654. Cipher Message(栈)
    Ural_1333. Genie Bomber 2
    POJ_2112 Optimal Milking(网络流)
    Ural_1031.Railway Ticket (DP)
    Ural_1030. Titanic
    Ural_1207. Median on the Plane(计算几何)
  • 原文地址:https://www.cnblogs.com/TenosDoIt/p/3465273.html
Copyright © 2011-2022 走看看