73. 矩阵置零

复制代码
https://leetcode.cn/problems/set-matrix-zeroes/description/?envType=study-plan-v2&envId=top-100-liked
复制代码
我们可以使用两个vector来记录需要置零的行和列,然后遍历这两个vector,将对应的行和列置零。这样的空间复杂度最大是O(n+m)
时间复杂度O(nm),空间复杂度O(n+m)
java 复制代码
    public void setZeroes(int[][] matrix) {
        HashSet<Integer> row = new HashSet<>();
        HashSet<Integer> col = new HashSet<>();
        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                if (matrix[i][j] == 0) {
                    row.add(i);
                    col.add(j);
                }
            }
        }
        for(int i = 0; i < matrix.length; i++) {
            for(int j = 0; j < matrix[0].length; j++) {
                if (row.contains(i) || col.contains(j)) {
                    matrix[i][j] = 0;
                }
            }
        }
    }
复制代码
因为当我们记录i,j是需要置0的行和列时,我们可以使用原矩阵的首行和首列置0来代替集合记录,因为后续操作这些位置也要置0的.时间复杂度O(nm),空间复杂度O(1)
java 复制代码
    public void setZeroes(int[][] matrix) {
        // 定义两个布尔变量,分别表示第一列和第一行是否有0
        boolean col0 = false, row0 = false;
        // 遍历第一列,如果有0,则将col0设为true
        for (int i = 0; i < matrix.length; i++) {
            if (matrix[i][0] == 0) col0 = true;
        }
        // 遍历第一行,如果有0,则将row0设为true
        for (int i = 0; i < matrix[0].length; i++) {
            if (matrix[0][i] == 0) row0 = true;
        }
        // 遍历除第一行和第一列外的所有元素,如果有0,则将对应的第一行和第一列元素设为0
        for (int i = 1; i < matrix.length; i++) {
            for (int j = 1; j < matrix[0].length; j++) {
                if (matrix[i][j] == 0) {
                    matrix[i][0] = 0;
                    matrix[0][j] = 0;
                }
            }
        }
        // 遍历第一列,如果有0,则将对应的所有行元素设为0
        for (int i = 1; i < matrix[0].length; i++) {
            if (matrix[0][i] == 0) {
                for (int j = 1; j < matrix.length; j++) {
                    matrix[j][i] = 0;
                }
            }
        }
        // 遍历第一行,如果有0,则将对应的所有列元素设为0
        for (int i = 1; i < matrix.length; i++) {
            if (matrix[i][0] == 0) {
                for (int j = 1; j < matrix[0].length; j++) {
                    matrix[i][j] = 0;
                }
            }
        }
        // 如果第一行有0,则将第一行所有元素设为0
        if(row0) {
            Arrays.fill(matrix[0], 0);
        }
        // 如果第一列有0,则将第一列所有元素设为0
        if(col0) {
            for(int i = 0; i < matrix.length; i++) {
                matrix[i][0] = 0;
            }
        }
    }
相关推荐
爱吃苹果的日记本3 分钟前
开学第一课
java
汉克老师8 分钟前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
共享家952714 分钟前
优先搜索(DFS)实战
算法·leetcode·深度优先
一只懒洋洋33 分钟前
中值滤波、方框滤波、高斯滤波、均值滤波、膨胀、腐蚀、开运算、闭运算
算法·均值算法
渣哥33 分钟前
Java 集合框架详解:常见集合类及分类方式
java
shellvon40 分钟前
你怎么被识别的?从TLS到Canvas的设备追踪术
后端·算法
yinke小琪44 分钟前
消息队列如何保证消息顺序性?从原理到代码手把手教你
java·后端·面试
薛定谔的算法1 小时前
JavaScript栈的实现与应用:从基础到实战
前端·javascript·算法
羚羊角uou1 小时前
【Linux】匿名管道和进程池
linux·c++·算法
考虑考虑1 小时前
Java实现墨水屏点阵图
java·后端·java ee