leetcode 73.矩阵置零

题目链接:leetcode 73

1.题目

给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。

2.示例

1)示例 1:

输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]

输出:[[1,0,1],[0,0,0],[1,0,1]]

2)示例 2:

输入:matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]

输出:[[0,0,0,0],[0,4,5,0],[0,3,1,0]]

3)提示:

m == matrix.length

n == matrix[0].length

1 <= m, n <= 200

-231 <= matrix[i][j] <= 231 - 1

3.分析

首先有一个最直观的方法,就是使用O(m*n)的额外空间,在另外一个数组上进行修改。在此基础上,我们可以分别存储某一行某一列是否包含零,这样就使用了O(m+n)的额外空间。那么我们在上述方法的基础上,使用matrix的第一排和第一列分别表示该格子所在的行或列是否包含零(因为当该行或列也存在0时候这个格子也会变成0)。同时,在最开始记录第一行和第一列是否原本就包含0即可。

4.代码

cpp 复制代码
class Solution {
public:
    map<int,int> map1,map2;
    void setZeroes(vector<vector<int>>& matrix) {
        //1.O(n+m)
        // for(int i=0;i<matrix.size();i++)
        //     for(int j=0;j<matrix[0].size();j++)
        //         if(matrix[i][j]==0){
        //             map1[i]=1;
        //             map2[j]=1;
        //         }
        // for(int i=0;i<matrix.size();i++)
        //     for(int j=0;j<matrix[0].size();j++)
        //         if(map1.count(i)!=0||map2.count(j)!=0)
        //             matrix[i][j]=0;

        //2.常量级
        bool row1=false,col1=false;
        int m=matrix.size(),n=matrix[0].size();
        for(int i=0;i<m;i++)
            if(matrix[i][0]==0) col1=true;
        for(int i=0;i<n;i++)
            if(matrix[0][i]==0) row1=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(row1)
            for(int i=0;i<n;i++) matrix[0][i]=0;
        if(col1)
            for(int i=0;i<m;i++) matrix[i][0]=0;
    }
};
相关推荐
岁忧几秒前
LeetCode 高频 SQL 50 题(基础版)之 【高级字符串函数 / 正则表达式 / 子句】· 上
sql·算法·leetcode
eachin_z1 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
机器学习之心1 小时前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。2 小时前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879673 小时前
省略号和可变参数模板
开发语言·c++·算法
飞川撸码4 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习4 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910135 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题5 小时前
算法练习-回溯
算法