18、矩阵-矩阵置零

题解:这道题不能直接双层遍历遇到0就开始行列置零,会影响下次循环遍历。所以可以通过两个集合来记录0所在的行和列,然后再双层遍历遇到标记置0,代码如下:

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        if (matrix==null||matrix.length==0){
            return;
        }
        Set<Integer> xSet = new HashSet<>();
        Set<Integer> ySet = new HashSet<>();
        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[i].length; j++) {
                if (matrix[i][j]==0){
                    xSet.add(i);
                    ySet.add(j);
                }
            }
        }
        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[i].length; j++) {
                if (xSet.contains(i)||ySet.contains(j)){
                    matrix[i][j]=0;
                }
            }
        }
    }
}
相关推荐
异常君12 分钟前
Apache Curator LeaderSelector:构建高可用分布式领导者选举机制
java·zookeeper·面试
Sun_light22 分钟前
队列:先进先出的线性数据结构及其应用
前端·javascript·算法
盛寒32 分钟前
零基础入门 线性代数
线性代数
codeRichLife43 分钟前
Mybatisplus3.5.6,用String处理数据库列为JSONB字段
java·数据库
来自星星的猫教授1 小时前
Java 文件注释规范(便于生成项目文档)
java·注释
吕小鸣1 小时前
Coze、Dify、FastGPT三大AI智能平台架构与能力对比
算法
zhimeng31 小时前
自己学习原理
java
程序员鱼皮1 小时前
学 Java 还是 Go 语言?这事儿很简单!
java·后端·计算机·程序员·开发·编程经验·自学编程
Lanqing_07601 小时前
淘宝商品详情图API接口返回参数说明
java·服务器·前端·api·电商
jndingxin1 小时前
c++ 面试题(1)-----深度优先搜索(DFS)实现
c++·算法·深度优先