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();
     }





    }
}
相关推荐
seeyoutlb1 分钟前
微服务全局日志处理
java·python·微服务
码界奇点16 分钟前
Java Web学习 第15篇jQuery从入门到精通的万字深度解析
java·前端·学习·jquery
雨落秋垣19 分钟前
手搓 Java 的用户行为跟踪系统
java·开发语言·linq
盖世英雄酱5813624 分钟前
java深度调试技术【第六七八章:宽字节与多字节】
java·后端
爱丽_1 小时前
深入理解 Java Socket 编程与线程池:从阻塞 I/O 到高并发处理
java·开发语言
济南壹软网络科技有限公司1 小时前
云脉IM的高性能消息路由与离线推送机制摘要:消息的“零丢失、低延迟”之道
java·即时通讯源码·开源im·企业im
Seven971 小时前
剑指offer-46、孩⼦们的游戏(圆圈中最后剩下的数)
java
serendipity_hky2 小时前
互联网大厂Java面试故事:核心技术栈与场景化业务问题实战解析
java·spring boot·redis·elasticsearch·微服务·消息队列·内容社区
我真不会起名字啊2 小时前
C、C++中的sprintf和stringstream的使用
java·c语言·c++
十点摆码2 小时前
Spring Boot2 使用 Flyway 管理数据库版本
java·flyway·数据库脚本·springboo2·数据库脚本自动管理