leetcode——矩阵置零(java)

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

示例 1:

复制代码
输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]

示例 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]]

解题方法:(标记数组)

1.首先我们需要建立两个标记数组,一个是用来标记行的,一个是用来标记列的。

2.然后我们开始遍历二维矩阵,如果遇到元素为0时,我们将两个标记矩阵相对应索引值位置设定为true

3.接着我们再次遍历二维矩阵,但是我们这一次还需要同时检查两个标记数组,如果其中有一个为true,我们将原矩阵相对应的索引值设定为0

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m = matrix.length, n = matrix[0].length;
        boolean[] row = new boolean[m];
        boolean[] col = new boolean[n];
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (matrix[i][j] == 0) {
                    row[i] = col[j] = true;
                }
            }
        }
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (row[i] || col[j]) {
                    matrix[i][j] = 0;
                }
            }
        }
    }
}
相关推荐
找不到、了9 分钟前
Spring-Beans的生命周期的介绍
java·开发语言·spring
caihuayuan427 分钟前
React Native 0.68 安装react-native-picker报错:找不到compile
java·大数据·sql·spring·课程设计
爱编程的鱼1 小时前
C#接口(Interface)全方位讲解:定义、特性、应用与实践
java·前端·c#
旋风菠萝1 小时前
深入理解Java中的Minor GC、Major GC和Full GC
java·jvm·gc
苹果酱05671 小时前
React方向:react脚手架的使用
java·vue.js·spring boot·mysql·课程设计
找不到、了1 小时前
JVM如何处理多线程内存抢占问题
java·jvm
zhougl9961 小时前
Apache HttpClient 5 用法-Java调用http服务
java·http·apache
spjhandsomeman1 小时前
各个历史版本mysql/tomcat/Redis/Jdk/Apache/gitlab下载地址
java·redis·mysql·jdk·tomcat·gitlab
JeffersonZU1 小时前
【数据结构】1-4算法的空间复杂度
c语言·数据结构·算法
L_cl1 小时前
【Python 算法零基础 4.排序 ① 选择排序】
数据结构·算法·排序算法