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;
    }
};
相关推荐
重庆小透明18 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
desssq37 分钟前
力扣:70. 爬楼梯
算法·leetcode·职场和发展
clock的时钟1 小时前
暑期数据结构第一天
数据结构·算法
小小小小王王王2 小时前
求猪肉价格最大值
数据结构·c++·算法
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 58. 最后一个单词的长度 (字符串)
java·c++·算法·leetcode·面试·go
BIYing_Aurora2 小时前
【IPMV】图像处理与机器视觉:Lec13 Robust Estimation with RANSAC
图像处理·人工智能·算法·计算机视觉
martian6654 小时前
支持向量机(SVM)深度解析:从数学根基到工程实践
算法·机器学习·支持向量机
孟大本事要学习4 小时前
算法19天|回溯算法:理论基础、组合、组合总和Ⅲ、电话号码的字母组合
算法
??tobenewyorker4 小时前
力扣打卡第二十一天 中后遍历+中前遍历 构造二叉树
数据结构·c++·算法·leetcode
让我们一起加油好吗4 小时前
【基础算法】贪心 (二) :推公式
数据结构·数学·算法·贪心算法·洛谷