lc73矩阵置零——尽可能减少空间复杂度

73. 矩阵置零 - 力扣(LeetCode)

法1:

很容易想到,O(m+n)空间复杂度,记录哪些行,哪些列有0。

法2:

常量空间,第一次做不太好想到。法1是用额外数组记录行列的0情况,法2优化为 用原矩阵的,第一列记录每行有0的情况,第一行用于记录每列有0的情况。而对于第一行和第一列本身就有0的情况,额外拿2个变量(常量)记录,有的话,把其置位0.

注意第二次遍历,从1,1开始,要忽略第一行和第一列。

复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        boolean rowExist = false;
        boolean colExist = false;

        int m = matrix.length;
        int n = matrix[0].length;      
        //第一次遍历,统计
        for(int i = 0;i<m;i++) {
            for(int j=0; j<n; j++) {
                if(matrix[i][j] == 0) {
                    if(i == 0)
                        rowExist = true;
                    if(j == 0)
                        colExist = true;
                    matrix[i][0] = 0;
                    matrix[0][j] = 0;
                }
            }
        }
        //第二次遍历变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;
            }
        }
        //是否第一行和第一列原本就有0
        if(rowExist) {
            for(int i = 0;i<n;i++)
                matrix[0][i] = 0;
        }
        if(colExist) {
            for(int i=0;i<m;i++)
                matrix[i][0]=0;
        }
    }
}

当然也可进一步优化,只用一个m[0][0]标记第1行有无0,再额外用一个变量记录第一列有无0即可。

相关推荐
战族狼魂4 小时前
40x40 矩阵控制系统
jvm·oracle·矩阵
一只小小的土拨鼠21 小时前
【国奖冲刺/全网首发】2026年第十四届“泰迪杯”A、B、C题完整解题思路、代码与高质量论文大合集
c语言·矩阵·数据挖掘
普中科技1 天前
【普中 51-Ai8051 开发攻略】-- 第 10 章 矩阵按键实验
单片机·嵌入式硬件·矩阵·开发板·普中科技·ai8051u·aicube
歪歪歪比巴卜1 天前
2026年AI新媒体运营工具怎么选?核心功能与适用场景解析
大数据·矩阵·新媒体运营
m0_743106461 天前
【3D硬核】四元数(Quaternions)与旋转矩阵(Rotation)——三维空间中的旋转
人工智能·计算机视觉·3d·矩阵·几何学
别或许1 天前
线代中为什么左乘一个列满秩矩阵,不改变矩阵的秩?
人工智能·算法·矩阵
wfbcg1 天前
每日算法练习:LeetCode 54. 螺旋矩阵 ✅
算法·leetcode·矩阵
Star Learning Python1 天前
《简单线性代数》-20260414
线性代数·决策树·机器学习
AI科技星2 天前
v=c 物理理论核心参数转换表达式大全
开发语言·线性代数·算法·数学建模·平面
_日拱一卒2 天前
LeetCode:240搜索二维矩阵Ⅱ
数据结构·线性代数·leetcode·矩阵