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;
            }
        }
    }
};
相关推荐
AI科技星16 分钟前
全域数学·第二部 几何本原部 《无穷维射影几何原本》合订典藏版【乖乖数学】
人工智能·线性代数·数学建模·矩阵·量子计算
风筝在晴天搁浅19 分钟前
剑指Offer 60.n个骰子的点数
算法
ProgramHelpOa23 分钟前
Optiver 2026 OA 全面复盘|26NG / Intern 最新高频题型整理
人工智能·算法·机器学习
feifeigo12324 分钟前
基于无迹变换的电网概率潮流分析 MATLAB 实现
开发语言·算法·matlab
Java成神之路-26 分钟前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋28 分钟前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
Struggle_975535 分钟前
算法知识-倍增算法
算法
计算机安禾38 分钟前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法
fie888941 分钟前
基于遗传算法的机械故障诊断MATLAB程序
算法·机器学习·matlab
nlpming1 小时前
opencode MCP(Model Context Protocol)配置手册
算法