【leetcode面试经典150题】37. 矩阵置零(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主,题解使用C++语言。(若有使用其他语言的同学也可了解题解思路,本质上语法内容一致)

【题目描述】

给定一个 mxn 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法**。**

【示例一】

复制代码
输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]

【示例二】

复制代码
输入:matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
输出:[[0,0,0,0],[0,4,5,0],[0,3,1,0]]

【提示及数据范围】

  • m == matrix.length
  • n == matrix[0].length
  • 1 <= m, n <= 200
  • -2的31次方 <= matrix[i][j] <= 2的31次方 - 1

【代码】

cpp 复制代码
// 使用标记数组

// 首先遍历该数组一次,如果某个元素为 0,
// 那么就将该元素所在的行和列所对应标记数组的位置置为 true。
// 最后我们再次遍历该数组,用标记数组更新原数组即可。

class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        int m = matrix.size();
        int n = matrix[0].size();
        vector<int> row(m),col(n);
        for(int i = 0;i<m;i++){
            for(int j = 0;j<n;j++){
                if(!matrix[i][j]) row[i] = col[j] = true;
            }
        }
        for(int i =0;i<m;i++){
            for(int j = 0;j<n;j++){
                if(row[i] || col[j]){
                    matrix[i][j] = 0;
                }
            }
        }
    }
};
相关推荐
涤生大数据11 小时前
大数据面试高频题:row_number() 数据倾斜到底怎么解决?
java·大数据·面试
alphaTao11 小时前
LeetCode 每日一题 2026/5/18-2026/5/24
python·leetcode
摇滚侠11 小时前
HashMap 源码解析 底层原理 面试如何回答
java·面试·职场和发展
悠仁さん11 小时前
数据结构 树 二叉树 堆 (堆的模拟实现篇)
数据结构
汉克老师12 小时前
GESP6级C++考试语法知识(二十七、广度优先搜索(二、二维BFS))
c++·算法·图论·宽度优先·广度优先搜索·gesp6级·gesp六级
此生决int12 小时前
算法从入门到精通——位运算
数据结构·c++·算法·蓝桥杯
春栀怡铃声12 小时前
【C++修仙录02】筑基篇:vector 使用
开发语言·c++·算法
救救孩子把12 小时前
66-机器学习与大模型开发数学教程-6-2 矩阵运算的数值误差分析
人工智能·机器学习·矩阵
Loli_Wolf12 小时前
AI 原生研发闭环:从提需到线上监测,再自动回到提需
人工智能·深度学习·算法·microsoft·ai·ai编程·harness
丁劲犇12 小时前
使用TraeAI开发Web页面测试MSYS2 ucrt64 Qt MCP服务器
服务器·前端·c++·qt·mcp