2025年- H17-Lc125-73.矩阵置零(矩阵)---java版

1.题目描述


2.思路

(1)计算矩阵的行数

(2)计算矩阵的列数

(3)设计一个行列的bool数组

(4)遍历矩阵(二维数组),如果遇到元素0,则把元素0所在的行和列全都置为true

(5)再次遍历矩阵(二维数组),如果行数组为true把行数组置为0,如果列数组为true把列数组置为0.

注意点:

3.代码实现

java 复制代码
public class H73 {

    public void setZeroes(int[][] matrix) {

        //1.计算矩阵的行数
        int m=matrix.length;

        //2.计算矩阵的列数
        int n=matrix[0].length;

        //3.设计一个行列的bool数组,boolean 是基本类型,默认值就是 false,不需要额外初始化。
        //Java 中数组初始化默认值为 null,而不是 false。
        //如果声明用Boolean,使用 row[i] == true 的时候,如果 row[i] 没被赋值过,就会变成 null == true,会抛出 NullPointerException。
        boolean[] row=new boolean[m];
        boolean[] col=new boolean[n];


        //4.遍历矩阵(二维数组),如果遇到元素0,则把元素0所在的行和列全都置为true
        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;

                }
            }
        }

        //5.再次遍历矩阵(二维数组),如果行数组为true把行数组置为0,如果列数组为true把列数组置为0.也就是把矩阵中的行列置为true的置为0
        for(int i=0;i<m;i++)
        {
            for(int j=0;j<n;j++)
            {
                if(row[i]==true||col[j]==true)
                {
                    matrix[i][j]=0;
                }
            }
        }

    }
    public static void main(String[] args)
    {
     H73 test08=new H73();
     int[][] matrix={{1,1,1},{1,0,1},{1,1,1}};
     test08.setZeroes(matrix);
     for(int[] row:matrix)//先遍历一维数组,行数组
     {
         for(int value:row)//再遍历列数组
         {
             System.out.print(value+" ");
         }
         System.out.println();
     }





    }
}
相关推荐
庞轩px19 小时前
第三篇:泛型深度解析——类型擦除与通配符的奥秘
java·编译·泛型·类型擦除
HoneyMoose1 天前
Jenkins Cloudflare 部署提示错误
java·servlet·jenkins
阿丰资源1 天前
基于SpringBoot的物流信息管理系统设计与实现(附资料)
java·spring boot·后端
Predestination王瀞潞1 天前
Java EE3-我独自整合(第四章:Spring bean标签的常见配置)
java·spring·java-ee
overmind1 天前
oeasy Python 121[专业选修]列表_多维列表运算_列表相加_列表相乘
java·windows·python
资深数据库专家1 天前
总账EBS 应用服务器1 的监控分析
java·网络·数据库
房开民1 天前
可变参数模板
java·开发语言·算法
t***5441 天前
如何在现代C++中更有效地应用这些模式
java·开发语言·c++
_深海凉_1 天前
LeetCode热题100-最小栈
java·数据结构·leetcode
不知名的忻1 天前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历