n*m 矩阵: set matrix zeroes

问题描述

有个 N * M 的矩阵,其中有的元素是 0,如果是 0,那么将该行和该列都设置为0. 需要 O(1) 的空间复杂度

问题分析

初看此问题,确实很简单,没有过多算法内容。

如果有 O( M + N) 的空间,那么可以存储所有的含有 0 的列和行。然后再逐一设置 0 即可。

现在要求是使用 O(1) 的空间复杂度,该如何处理?

问题求解

  • 扫描 (Row >= 1 && Column >= 1) 的元素,如果元素为0,则将第一行和第一列对应的位置设置为0
  • 扫描完矩阵后,所有的 0 的信息都保存在第一行和第一列中了。这样去扫描第一行和第一列,如果遇到0,则将整列或整行设置0.

具体代码:

    void setZeroes(vector<vector<int> > &matrix) {
        int n = matrix.size();
        if (n <= 0) return;
        int m = matrix[0].size();
        bool firstRowHas0 = false;
        for (int i = 0; i < m; i++) if (matrix[0][i] == 0) firstRowHas0 = true;
        bool firstColumnHas0 = false;
        for (int i = 0; i < n; i++) if (matrix[i][0] == 0) firstColumnHas0 = true;
        for (int i = 1; i < n; i++) for (int j = 1; j < m; j++) if (matrix[i][j] == 0) matrix[0][j] = matrix[i][0] = 0;
        for (int i = 1; i < n; i++) if (matrix[i][0] == 0) { for (int j = 0; j < m; j++) matrix[i][j] = 0; }
        for (int i = 1; i < m; i++) if (matrix[0][i] == 0) { for (int j = 0; j < n; j++) matrix[j][i] = 0; }
        if (firstRowHas0) for (int i = 0; i < m; i++) matrix[0][i] = 0;
        if (firstColumnHas0) for (int i = 0; i < n; i++) matrix[i][0] = 0;

    }
时间: 2024-10-11 19:46:02

n*m 矩阵: set matrix zeroes的相关文章

LeetCode:Set Matrix Zeroes - 将矩阵内含有零的行和列全部置零

1.题目名称 Set Matrix Zeroes(将矩阵内含有零的行和列全部置零) 2.题目地址 https://leetcode.com/problems/set-matrix-zeroes/ 3.题目内容 英文:Given a m x n matrix, if an element is 0, set its entire row and column to 0. 中文:给定一个m×n的矩阵,如果其中一个元素是0,则将该元素所在的整行或整理全部置为0 4.解题方法1 使用第一行和第一列记录某

【LeetCode-面试算法经典-Java实现】【070-Set Matrix Zeroes(矩阵置零)】

[070-Set Matrix Zeroes(矩阵置零)] [LeetCode-面试算法经典-Java实现][所有题目目录索引] 原题 Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. 题目大意 给定一个m*n的矩阵,如果某个位置是0.将对应的行和列设置为0. 解题思路 先对矩阵进行扫描,标记要进行置0的行和列,对要进行置0的行在第0列上进行标记,对置0的列在

[CareerCup] 1.7 Set Matrix Zeroes 矩阵赋零

1.7 Write an algorithm such that if an element in an MxN matrix is 0, its entire row and column are set to 0. LeetCode中的原题,请参见我之前的博客Set Matrix Zeroes 矩阵赋零.

LeetCode 第 73 题 (Set Matrix Zeroes)

LeetCode 第 73 题 (Set Matrix Zeroes) Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Follow up: Did you use extra space? A straight forward solution using O(mn) space is probably a bad idea. A simple impro

Set Matrix Zeroes

73 Set Matrix Zeroes 原文链接:http://blog.csdn.net/doc_sgl/article/details/11834933 Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Follow up: Did you use extra space?A straight forward solution using O(mn) s

【leetcode刷题笔记】Set Matrix Zeroes

Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. 题解:因为题目要求原地算法,所以我们只能利用矩阵第一行和第一列存放置零信息. 首先遍历第一行和第一列,看他们是否需要全部置零,用两个变量first_column_zero和first_row_zero来记录: 遍历矩阵,如果某个位置matrix[i][j]出现了0,就把matrix[i][0]和Matrix[0

Leetcode 细节实现 Set Matrix Zeroes

Set Matrix Zeroes Total Accepted: 18139 Total Submissions: 58671My Submissions Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. click to show follow up. 题意:给定矩阵,如果矩阵的某个位置为0,则把那一行那一列的所有元素都置为0 思路:用两个bool数组,分

LeetCode: Set Matrix Zeroes [073]

[题目] Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. [题意] 给定一个mXn的矩阵,如果其中的元素为0,则对应的行和列都用0填充. 不能申请额外的空间. [思路] 第一行和第一列空出来标记需要置0的列和行 第一遍扫描: 扫描第一行,判断第一行是否需要清零 扫描第一列,判断第一列是否需要清零 扫描[1,1]~[m-1, n-1]的区块,如果某个位置上的值

【Leetcode】Set Matrix Zeroes

Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Could you devise a constant space solution? 思路:因为需要遍历整个矩阵,时间复杂度肯定需要O(m * n),对于空间复杂度而言,第一种是可以使用O(m * n),对每个位置的0的情况进行记录,第二种是使用O(m + n),对每行每列是否存在0进行记录,第三种是O(1)