[数组基础] 0073. 矩阵置零

文章目录

      • [1. 题目链接](#1. 题目链接)
      • [2. 题目大意](#2. 题目大意)
      • [3. 示例](#3. 示例)
      • [4. 解题思路](#4. 解题思路)
      • [5. 参考代码](#5. 参考代码)

1. 题目链接

0073. 矩阵置零 - 力扣

2. 题目大意

描述:给定一个 m×n 大小的矩阵 matrix。

要求:如果一个元素为 0,则将其所在行和列所有元素都置为 0。

说明

  • 请使用「原地」算法。
  • m==matrix.length。
  • n==matrix[0].length。
  • 1≤m,n≤200。
  • −231≤matrix[i][j]≤231−1。

进阶:

  • 一个直观的解决方案是使用 O(m×n) 的额外空间,但这并不是一个好的解决方案。
  • 一个简单的改进方案是使用 O(m+n) 的额外空间,但这仍然不是最好的解决方案。
  • 你能想出一个仅使用常量空间的解决方案吗?

3. 示例

java 复制代码
输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]
java 复制代码
输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]

4. 解题思路

  1. 设定两个变量 flag‾row0、flag‾col0 来标记第一行、第一列是否出现了 0。
  2. 接下来我们使用数组第一行、第一列来标记 0 的情况。
  3. 对数组除第一行、第一列之外的每个元素进行遍历,如果某个元素出现 0 了,
    则使用数组的第一行、第一列对应位置来存储 0 的标记。
  4. 再对数组除第一行、第一列之外的每个元素进行遍历,通过对第一行、第一列的标记 0 情况,进行置为 0 的操作。
  5. 最后再根据 flag‾row0、flag‾col0 的标记情况,对第一行、第一列进行置为 0 的操作。

5. 参考代码

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m=matrix.length;
        int n=matrix[0].length;
        boolean flagRow=false;
        boolean flagCol=false;
        
        for(int i=0; i<m; i++){
            if(matrix[i][0] == 0){
                flagCol=true;
            }
        }
        
        for(int j=0; j<n; j++){
            if(matrix[0][j] == 0){
                flagRow=true;
            }
        }
        
        for(int i=1; i<m; i++){
            for(int j=1; j<n; j++){
                if(matrix[i][j] == 0){
                    matrix[i][0]=matrix[0][j]=0;
                }
            }
        }
        
        for(int i=1; i<m; i++){
            for(int j=1; j<n; j++){
                if(matrix[i][0]==0 || matrix[0][j]==0){
                    matrix[i][j]=0;
                }
            }
        }
        
        if(flagRow){
            for(int j=0; j<n; j++){
                matrix[0][j]=0;
            }
        }
        
        if(flagCol){
            for(int i=0; i<m; i++){
                matrix[i][0]=0;
            }
        }
    }
}
相关推荐
橘颂TA1 分钟前
【剑斩OFFER】算法的暴力美学——山脉数组的蜂顶索引
算法·leetcode·职场和发展·c/c++
速易达网络13 分钟前
C语言常见推理题
java·c语言·算法
freedom_1024_30 分钟前
LRU缓存淘汰算法详解与C++实现
c++·算法·缓存
博语小屋37 分钟前
力扣11.盛水最多的容器(medium)
算法·leetcode·职场和发展
Swift社区44 分钟前
LeetCode 423 - 从英文中重建数字
算法·leetcode·职场和发展
点云SLAM1 小时前
算法与数据结构之二叉树(Binary Tree)
数据结构·算法·二叉树·深度优先·广度优先·宽度优先
小龙报1 小时前
《算法通关指南:算法基础篇 --- 一维前缀和 — 1. 【模板】一维前缀和,2.最大子段和》
c语言·数据结构·c++·算法·职场和发展·创业创新·visual studio
bbq粉刷匠2 小时前
力扣--两数之和(Java)
java·leetcode
树在风中摇曳2 小时前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode
不夜牛仔2 小时前
算法笔记17 - 贪心算法介绍与思路 | 路灯摆放问题 | 活动安排问题 | 最低字典序拼接 | 金条分割问题 | 项目投资问题
笔记·算法·贪心算法