Leetcode hot100 矩阵置零【中等】

法(一)一个非常简单,3分钟就能写出来的解法

先遍历一遍矩阵,用boolean\[\] row\[\] 和boolean\[\] col去记录哪些行和哪些列是0.想·

然后再遍历一遍矩阵,置0

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m = matrix.length;  //行
        int n = matrix[0].length;  //列

        boolean[] row = new boolean[m];
        boolean[] col = new boolean[n];
        
        //标记哪些行,哪些列是0
        for(int i=0;i<m;i++){
            for (int j=0; j<n; j++){
                if(matrix[i][j]==0){
                    row[i]=true;
                    col[j]=true;
                }
            }
        }
        
        //填充0
        for(int i=0;i<m;i++){
            for (int j=0; j<n; j++){
                if(row[i]||col[j]){
                    matrix[i][j]=0;
                }
            }
        }
    }
}

空间复杂度:O(m+n)

然后,让用O(1)的空间复杂度,给出的方法是,占用原矩阵第一行和第一列用来标记。。。无语了,为了省而省,一点也不优雅。。

但是呢,也有很多要考虑的地方。

(1)考虑既然在原有矩阵基础上标记,那就不能用boolean类型了,只能用int类型,如何标记呢?分析了一下,用0标记就好了。这样最后我们填充0的时候,只要matrixi0==0(或者matrix0i==0),这一行(列)就都标记0。即使是matrixi0本来就是0,那最后填充的时候,这一行也都标记为0,没毛病。

(2)考虑需要一开始对第一行和第一列做清空处理吗,还是什么都不用做。答案是什么都不用做。保留第一行和第一列的原数据,然后遍历去掉第一行和第一列的"小矩形",去覆盖第一行和第一列的值。

(3)还有就是,不能只管"小矩形"啊。一开始要遍历第一行和第一列,看看第一行和第一列里是否有0,这里会用到额外的空间去记录

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
                int m = matrix.length;  //行
        int n = matrix[0].length;  //列

        boolean firstRow = false;
        boolean firstCol = false;
        
        //记录第一行和第一列是否有0
        for(int j=0; j<n; j++){
            if(matrix[0][j]==0) firstRow=true;
        }
        
        for (int i=0; i<m; i++){
            if(matrix[i][0]==0) firstCol=true;
        }
        
        //标记哪些行,哪些列是0
        //注意,遍历的是小矩阵,从i和j都是1开始
        for(int i=1;i<m;i++){
            for (int j=1; j<n; j++){
                if(matrix[i][j]==0){
                    matrix[i][0]=0;
                    matrix[0][j]=0;
                }
            }
        }

        //填充0
        //注意,填充的是小矩阵,从i和j都是1开始
        for(int i=1;i<m;i++){
            for (int j=1; j<n; j++){
                if(matrix[i][0]==0||matrix[0][j]==0){
                    matrix[i][j]=0;
                }
            }
        }
        
        //最后填充第0行和第0列
        if(firstRow){
            for(int j=0; j<n; j++){
               matrix[0][j]=0;
            }
        }
        
        if(firstCol){
            for (int i=0; i<m; i++){
                matrix[i][0]=0;
            }
        }
    }
}

整个过程有点像穿脱原则。

相关推荐
AI_yangxi3 分钟前
短视频矩阵系统供应商
大数据·人工智能·矩阵
Jerryhut19 分钟前
opencv对齐算法及其应用
人工智能·opencv·算法
果丁智能30 分钟前
智慧校园一卡通深度融合方案:基于超级SIM卡的手机碰一碰智能开锁技术落地实践
数据结构·人工智能·python·科技·算法·智能家居·信息与通信
满怀冰雪38 分钟前
第13篇-栈算法入门-括号匹配-表达式与单调栈基础
java·算法
TCW112141 分钟前
AI底层系列:用C++实现线性代数的公式推导与算法设计-基础篇-5.矩阵方程
人工智能·线性代数·算法
叫我:松哥43 分钟前
基于机器学习和flask的体育健身风险智能分析系统,系统集成DeepSeek、聚类算法、分类算法等,准确率达90%
人工智能·python·神经网络·算法·机器学习·flask·聚类
wabs6661 小时前
关于动态规划【0-1背包思想在实际问题中是怎么转化的?】
算法·动态规划
阿文的代码库1 小时前
欧拉回路与欧拉路径的算法流程演示
算法
汤姆yu1 小时前
云知声 U2 原生智能体大模型深度解析
大数据·人工智能·算法·ai·大模型·多模态·智能体
syt_biancheng1 小时前
贪心算法(1)---简介
算法·贪心算法