力扣HOT100之矩阵:73. 矩阵置零

这道题我没有想到什么好的办法,直接暴力AC了,直接遍历两次矩阵,第一次遍历用两个向量分别记录出现0的行数和列数,第二次遍历就判断当前的元素的行数或者列数是否出现在之前的两个向量中,若出现了就直接置零,否则就跳过。后面看了下空间复杂度为O(1)的解法,感觉这个思路不错,记录一下。

我们可以将第0行和第0列作为记录的标志位,例如matrix[5][6] == 0,我们就将matrix[0][6]matrix[5][0]置为0,经过一次遍历后,除了第0行和第0列的情况没有统计出来,其余的行和列都已经遍历结束并且打上标签,由于打标签会向第0行和第0列添加0,打完标签后无法判断其本身原本就包含0,因此在遍历矩阵打标签之前,我们需要遍历矩阵的第0行和第0列,如果他们本身就有0,我们就分别用两个变量记录下来,至此,我们先分别遍历了矩阵的第0行和第0列,再遍历了矩阵的其余行和列,这就遍历了一次矩阵,我们再遍历一次矩阵,从下标为1的行和列开始,对于matrix[i][j],如果matrix[0][j] == 0matrix[i][0] == 0,我们就直接将matrix[i][j]置零。遍历结束后,我们还需要对第0行和第0列进行处理,如果他们原本就包含0,则将整行或整列直接置零。这里依然是遍历两次数组,但是由于只进行了比较操作,而没有进行查找操作,程序耗时要比我之前暴力AC短得多。

下面分别是暴力AC代码(空间复杂度O(m + n))和空间复杂度O(1)的代码。

cpp 复制代码
//暴力代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        vector<int> row;
        vector<int> column;
        for(int i = 0; i < matrix.size(); ++i){
            for(int j = 0; j < matrix[i].size(); ++j){
                if(matrix[i][j] == 0){
                    row.emplace_back(i);
                    column.emplace_back(j);
                }
            }
        }
        for(int i = 0; i < matrix.size(); ++i){
            for(int j = 0; j < matrix[i].size(); ++j){
                if(find(row.begin(), row.end(), i) == row.end() 
                    && find(column.begin(), column.end(), j) == column.end())
                    continue;
                matrix[i][j] = 0;
            }
        }
    }
};
cpp 复制代码
//空间复杂度O(1)代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        bool row_flag0 = false;   //判断第0行有没有0
        bool column_flag0 = false;  //判断第0列有没有0
        //遍历第0行
        for(int i = 0; i < matrix[0].size(); ++i){
            if(matrix[0][i] == 0){
                row_flag0 = true;
                break;
            }
        }
        //遍历第0列
        for(int i = 0; i < matrix.size(); ++i){
            if(matrix[i][0] == 0){
                column_flag0 = true;
                break;
            }
        }
        //遍历整个矩阵,在第0行和第0列标记0元素的分布情况
        for(int i = 1; i < matrix.size(); ++i){
            for(int j = 1; j < matrix[i].size(); ++j){
                if(matrix[i][j] == 0){
                    matrix[i][0] = 0;  //在第0列的对应位置置零
                    matrix[0][j] = 0;  //在第0行的对应位置置零
                }
            }
        }
        //开始置零
        for(int i = 1; i < matrix.size(); ++i){
            for(int j = 1; j < matrix[i].size(); ++j){
                if(matrix[i][0] == 0 || matrix[0][j] == 0)
                    matrix[i][j] = 0;  
            }
        }
        //判断在打标记之前第0行本身有没有0
        if(row_flag0){
            for(int i = 0; i < matrix[0].size(); ++i)
                matrix[0][i] = 0;
        }
        //判断在打标记之前第0列本身有没有0
        if(column_flag0){
            for(int i = 0; i < matrix.size(); ++i)
                matrix[i][0] = 0;
        }
    }
};
相关推荐
山登绝顶我为峰 3(^v^)324 分钟前
如何录制带备注的演示文稿(LaTex Beamer + Pympress)
c++·线性代数·算法·计算机·密码学·音视频·latex
Two_brushes.1 小时前
【算法】宽度优先遍历BFS
算法·leetcode·哈希算法·宽度优先
森焱森4 小时前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack5 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客6 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠6 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988947 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼7 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield8 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦8 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt