力扣热门100题之矩阵置零

这道题要求不能用额外空间 ,必须用矩阵第一行、第一列当作标记位,是面试高频题!

核心思路(原地算法)

  1. 用第一行、第一列本身记录哪些行、哪些列需要置 0
  2. 先单独判断第一行、第一列本身是否有 0
  3. 遍历其他元素,遇到 0 就标记到第一行对应列第一列对应行
  4. 根据标记把对应行、列置 0
  5. 最后处理第一行、第一列

超级通俗大白话解释

1. 为什么要单独标记第一行、第一列?

因为第一行、第一列要用来当标记位,不能先把它们直接置 0,否则会丢失原本的标记信息。

2. 核心标记规则

  • 如果 matrix[i][j] = 0
  • 就让 第一行第 j 列 = 0(表示这一列要清零)
  • 就让 第 i 行第一列 = 0(表示这一行要清零)

3. 最后清零

  • 看第一列 → 哪行标 0 → 整行清零
  • 看第一行 → 哪列标 0 → 整列清零
  • 最后根据一开始记录的 firstRowfirstCol 清零第一行、第一列

完整代码实现

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m = matrix.length; // 行数
        int n = matrix[0].length; //列数

        // 标记:第一行是否有 0
        boolean firstRow = false;
        // 标记:第一列是否有 0
        boolean firstCol = false;

        // 检查第一行是否有0
        for (int j = 0; j < matrix[0].length; j++) {
            if (matrix[0][j] == 0) {
                firstRow = true;
                break;
            }
        }

        // 检查第一列是否有0
        for (int i = 0; i < matrix.length; i++) {
            if (matrix[i][0] == 0) {
                firstCol = true;
                break;
            }
        }

        // 3. 遍历除第一行、第一列外的元素
        // 如果 matrix[i][j] == 0,就标记到第一行和第一列
        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
                if (matrix[i][j] == 0) {
                    matrix[i][0] = 0; // 标记第 i 行需要置 0
                    matrix[0][j] = 0; // 标记第 j 列需要置 0
                }
            }
        }

        // 4. 根据第一列的标记,把对应行置为0
        for (int i = 1; i < m; i++) {
            if (matrix[i][0] == 0) {
                for (int j = 1; j < n; j++) {
                    matrix[i][j] = 0;
                }
            }
        }

        // 根据第一行的标记 把对应列置为0
        for(int j = 1; j < n; j++){
            if(matrix[0][j] == 0){
                for(int i = 1;i<m;i++){
                    matrix[i][j] = 0;
                }
            }
        }

        //最后处理第一行
        if(firstRow){
            for(int j = 0;j<n;j++){
                matrix[0][j] = 0;
            }
        }

        //处理第一列
        if(firstCol){
            for(int i = 0;i<m;i++){
                matrix[i][0] = 0;
            }
        }
    }
}
相关推荐
Jiangxl~1 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢2 小时前
wolfram详解山峦算法
前端·算法
counting money2 小时前
prim算法最小生成树(java)
算法
澈2072 小时前
C++面向对象:类与对象核心解析
c++·算法
用户690673881922 小时前
基于无人机的单目测距系统,平均误差仅2.12%
算法
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
dinl_vin2 小时前
LangChain 系列·(四):RAG 基础——给大模型装上“外脑“
人工智能·算法·langchain
探物 AI3 小时前
【感知·医学分割】当 YOLOv11 杀入医学赛道:先检测后分割的级联架构
算法·yolo·计算机视觉·架构
隔壁大炮3 小时前
Day06-08.CNN概述介绍
人工智能·pytorch·深度学习·算法·计算机视觉·cnn·numpy
白云千载尽3 小时前
前馈与反馈——经典控制理论中的基础概念
人工智能·算法