[Java][Leetcode middle] 73. 矩阵置零

官解1: 使用第一行和第一列当作标记位

  • 使用第一行和第一列当作标记位
  • 另外用两个变量记录第一行第一列是否有0
java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
         if(matrix == null || matrix.length == 0 || matrix[0].length == 0) return;
         int m = matrix.length;
         int n = matrix[0].length;

        boolean row0 = false;
        boolean col0 = false;
 
        // 记录第一行第一列元素是否包含0(因为第一行第一列元素会被后续覆盖)
        for(int i = 0; i<m;i++){
            if(matrix[i][0] == 0) {
                row0 = true;
                break;
            }
        }
        for(int j = 0; j<n;j++){
            if(matrix[0][j] == 0) {
                col0 = true;
                break;
            }
        }
        // 使用第一行第一列,标记从第二行第二列元素开始是否包含0
        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;
                }
             }
        }

        // 根据第一行、第一列的情况开始往矩阵中填充0
        for(int i = 1;i<m;i++){
            if(matrix[i][0] == 0){
                for(int j = 1;j<n;j++)  matrix[i][j] = 0;
            }
        }
        for(int j = 1;j<n;j++){
            if(matrix[0][j] == 0){
                for(int i = 1;i<m;i++)  matrix[i][j] = 0;
            }
        }

        // 处理第一行、列
        if(row0){
            for(int i= 0;i<m;i++)  matrix[i][0] = 0;
        }
        if(col0){
            for(int j = 0;j<n;j++)  matrix[0][j] = 0;
        }
    }
}

代码精简

这里:

java 复制代码
        // 根据第一行、第一列的情况开始往矩阵中填充0
        for(int i = 1;i<m;i++){
            if(matrix[i][0] == 0){
                for(int j = 1;j<n;j++)  matrix[i][j] = 0;
            }
        }
        for(int j = 1;j<n;j++){
            if(matrix[0][j] == 0){
                for(int i = 1;i<m;i++)  matrix[i][j] = 0;
            }
        }

也可以写成这样:

java 复制代码
        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;
                }
            }
        }

官解2: 仅使用一个变量col0

这个理解起来有点困难。

  • 循环置0时,从最后一行开始向前遍历:因为第一行是后面所有元素的标志位,如果先把第一行元素置0,后面所有元素都会变成0.
  • 为什么需要且仅需要一个标志变量col0:对于第一列来说,它的元素被覆盖用作行标识,所以需要一个变量来记录是否需要清零;而对第一行来说,虽然它被当作列标识,但是matrix00 作为第一行是否需要清零的标志,因此不需要额外的row0.
java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
         if(matrix == null || matrix.length == 0 || matrix[0].length == 0) return; 
         int m = matrix.length;
         int n = matrix[0].length;

        boolean col0 = false;
 
        for(int i = 0; i<m;i++){
            // 第一列为0
            if(matrix[i][0] == 0)  col0 = true;
            for(int j = 1;j<n ;j++){
                if(matrix[i][j] == 0){
                    matrix[0][j] = 0;
                    matrix[i][0] = 0;
                }
            }
        }

       
        for(int i = m -1;i >= 0;i--){
            for(int j = n-1;j >= 1;j--){
                if( matrix[i][0] == 0 || matrix[0][j] == 0){
                    matrix[i][j] = 0;
                }
            }
            if(col0){
                matrix[i][0] = 0;
            }
        }
    }
}
相关推荐
咖啡八杯1 小时前
GoF设计模式——策略模式
java·后端·spring·设计模式
To_OC4 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
用户128526116029 小时前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java
Linsk9 小时前
组件 = 模板 + 业务逻辑
java·前端·vue.js
星沉远浦10 小时前
用Gemini高效解决Java代码报错难以定位的问题
java
用户2986985301413 小时前
Word 文档字符级格式化:Java 实现方案详解
java·后端
笨鸟飞不快14 小时前
从单个服务到集群:一次完整的性能排查复盘
java·前端
荣码14 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
SamDeepThinking14 小时前
Java微服务练习方式
java·后端·微服务
朦胧之1 天前
AI 编程-老项目改造篇
java·前端·后端