矩阵置零(中等)

可以用两个标记数组分别记录每一行和每一列是否有零出现。

首先遍历该数组一次,如果某个元素为 0,那么就将该元素所在的行和列所对应标记数组的位置置为 true。然后再次遍历该数组,用标记数组更新原数组。

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m=matrix.length;
        int n=matrix[0].length;
        boolean[] r=new boolean[m];
        boolean[] c=new boolean[n];
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(matrix[i][j]==0){
                    r[i]=true;
                    c[j]=true;
                }
            }
        }
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(r[i]||c[j]){
                    matrix[i][j]=0;
                }
            }
        }
        
    }
}
相关推荐
Sheep Shaun31 分钟前
C++类与对象—下:夯实面向对象编程的阶梯
c语言·开发语言·数据结构·c++·算法
yi个名字2 小时前
链表高级操作与算法
数据结构·算法·链表
wuqingshun3141592 小时前
蓝桥杯 19. 植树
c++·算法·蓝桥杯·深度优先·动态规划
王禄DUT2 小时前
网络延时 第四次CCF-CSP计算机软件能力认证
c++·算法
雨落俊泉2 小时前
2025-04-26-利用奇异值重构矩阵-美团
线性代数·矩阵·重构
方方土3333 小时前
ABC 404
数据结构·算法·图论
wang__123003 小时前
力扣119题解
算法·leetcode·职场和发展
I AM_SUN4 小时前
42. 接雨水(相向双指针/前后缀分解),一篇文章讲透彻
c++·算法·leetcode
毛茸茸斑斑点点4 小时前
补题( Convolution, 二维卷积求输出矩阵元素和最大值)
线性代数·矩阵