LeetCode 刷题【73. 矩阵置零】

73. 矩阵置零

自己做

解:标记消除

cpp 复制代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        vector<bool> x(matrix.size(), false);              //要置0的行
        vector<bool> y(matrix[0].size(), false);           //要置0的列
              
        //找出所有0元素
        for(int i = 0; i < (int)matrix.size(); i++)
            for(int j = 0; j < (int)matrix[0].size(); j++)
                if(matrix[i][j] == 0){
                    x[i] = true;        //该行要置0
                    y[j] = true;        //该列要置0
                }

        //置空行   
        for(int i = 0; i < (int)matrix.size(); i++)
            if(x[i])                   //该行需要置0
                for(int j = 0; j < (int)matrix[0].size(); j++)
                    matrix[i][j] = 0;
            
        
        
        //置空列
        for(int j = 0; j < (int)matrix[0].size(); j++)        
            if(y[j])                   //该列需要置0
                for(int i = 0; i < (int)matrix.size(); i++)
                    matrix[i][j] = 0;
                        
    }
};

看题解

解:利用已有空间保存数据

官方代码:

cpp 复制代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        int m = matrix.size();
        int n = matrix[0].size();
        int flag_col0 = false, flag_row0 = false;
        for (int i = 0; i < m; i++) {
            if (!matrix[i][0]) {
                flag_col0 = true;
            }
        }
        for (int j = 0; j < n; j++) {
            if (!matrix[0][j]) {
                flag_row0 = true;
            }
        }
        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
                if (!matrix[i][j]) {
                    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] || !matrix[0][j]) {
                    matrix[i][j] = 0;
                }
            }
        }
        if (flag_col0) {
            for (int i = 0; i < m; i++) {
                matrix[i][0] = 0;
            }
        }
        if (flag_row0) {
            for (int j = 0; j < n; j++) {
                matrix[0][j] = 0;
            }
        }
    }
};
相关推荐
虾..10 分钟前
Linux 简单日志程序
linux·运维·算法
Trent198517 分钟前
影楼精修-眼镜祛反光算法详解
图像处理·人工智能·算法·计算机视觉·aigc
蓝色汪洋19 分钟前
经典修路问题
开发语言·c++·算法
csuzhucong29 分钟前
122魔方、123魔方
算法
Salt_072842 分钟前
DAY 40 早停策略和模型权重的保存
人工智能·python·算法·机器学习
卜锦元1 小时前
Golang后端性能优化手册(第三章:代码层面性能优化)
开发语言·数据结构·后端·算法·性能优化·golang
Binky6781 小时前
力扣--回溯篇(2)
算法·leetcode·职场和发展
De-Alf2 小时前
Megatron-LM学习笔记(6)Megatron Model Attention注意力与MLA
笔记·学习·算法·ai
2401_841495642 小时前
【LeetCode刷题】打家劫舍
数据结构·python·算法·leetcode·动态规划·数组·传统dp数组
冰西瓜6002 小时前
STL——vector
数据结构·c++·算法