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;
            }
        }
    }
};
相关推荐
闪电麦坤951 小时前
Leecode热题100:缺失的第一个正数(数组)
数据结构·算法·leetcode
梨子串桃子_8 小时前
推荐系统学习笔记 | PyTorch学习笔记
pytorch·笔记·python·学习·算法
夏鹏今天学习了吗8 小时前
【LeetCode热题100(83/100)】最长递增子序列
算法·leetcode·职场和发展
情缘晓梦.9 小时前
C语言指针进阶
java·开发语言·算法
北邮刘老师9 小时前
智能体治理:人工智能时代信息化系统的全新挑战与课题
大数据·人工智能·算法·机器学习·智能体互联网
AlenTech10 小时前
155. 最小栈 - 力扣(LeetCode)
算法·leetcode·职场和发展
mit6.82410 小时前
正反两次扫描|单调性cut
算法
Yzzz-F10 小时前
牛客小白月赛127 E
算法
大锦终10 小时前
递归回溯综合练习
c++·算法·深度优先
Keep__Fighting11 小时前
【神经网络的训练策略选取】
人工智能·深度学习·神经网络·算法