第73题 矩阵置零

题目

给定一个 mxn 的矩阵,如果一个元素为 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]]

提示:

  • m == matrix.length
  • n == matrix[0].length
  • 1 <= m, n <= 200
  • -231 <= matrix[i][j] <= 231 - 1

思路

创建两个set集合用来记录矩阵中值为零的行数 h 集合和列数 l 集合

遍历整个矩阵找到值为零的数把行数和列数分别添加到两个set集合中

遍历行数 h 集合,把这些行数的所有列的值置为0

遍历列数 l 集合,把这些列数的所有行的值置为0

代码示例

java 复制代码
import java.util.*;
public class lc73 {
    public static void main(String[] args) {
        int[][] matrix = {{0,1,2,0}, {3,4,5,2}, {1,3,1,5}};
        lc73 lc73 = new lc73();
        lc73.setZeroes(matrix);
        for (int i = 0; i < matrix.length; i++) {
            System.out.println(Arrays.toString(matrix[i]));
        }
    }
    public void setZeroes(int[][] matrix) {
        //创建两个set集合用来记录矩阵中值为零的行数 h 集合和列数 l 集合
        Set<Integer> h = new HashSet<>();
        Set<Integer> l = new HashSet<>();
        //遍历整个矩阵找到值为零的数把行数和列数分别添加到两个set集合中
        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                if(matrix[i][j]==0){
                    h.add(i);
                    l.add(j);
                }
            }
        }
        //遍历行数 h 集合,把这些行数的所有列的值置为0
        for (Integer val : h) {
            for (int i = 0; i < matrix[0].length; i++) {
                matrix[val][i] = 0;
            }
        }
        //遍历列数 l 集合,把这些列数的所有行的值置为0
        for (int i = 0; i < matrix.length; i++) {
            for (Integer val : l) {
                matrix[i][val] = 0;
            }
        }
    }
}
相关推荐
m0_6294947311 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户11 小时前
用队列实现栈
数据结构·算法
做人求其滴11 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad77711 小时前
记一组无人机IMU传感器数据
算法
计算机安禾11 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
AI科技星11 小时前
哥德巴赫猜想1+1基于平行素数对等腰梯形网格拓扑与素数渐近密度的大偶数满填充完备性证明
人工智能·线性代数·架构·概率论·学习方法
小O的算法实验室12 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-12 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~12 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界12 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构