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;
            }
        }
    }
};
相关推荐
Jack2013 分钟前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE21218 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21218 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法