Leetcode 73. 矩阵置零

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

示例 1:
在这里插入图片描述

输入:matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出:[[1,0,1],[0,0,0],[1,0,1]]

示例 2:
在这里插入图片描述

输入: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
-231 <= matrix[i][j] <= 231 - 1

思路:
方法一: 用 O(m+n)额外空间
两遍扫matrix,第一遍用集合记录哪些行,哪些列有0;第二遍置0

python:

class Solution:
    def setZeroes(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        row=len(matrix)
        col=len(matrix[0])
        row0=set()
        col0=set()
        for i in range(row):
            for j in range(col):
                if matrix[i][j]==0:
                    row0.add(i)
                    col0.add(j)

        for i in range(row):
            for j in range(col):
                if i in row0 or j in col0:
                    matrix[i][j]=0

思路二: 用O(1)空间
关键思想: 用matrix第一行和第一列记录该行该列是否有0,作为标志位
但是对于第一行,和第一列要设置一个标志位,为了防止自己这一行(一列)也有0的情况.

python:

class Solution:
    def setZeroes(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        row = len(matrix)
        col = len(matrix[0])
        row0_flag = False
        col0_flag = False
        # 找第一行是否有0
        for j in range(col):
            if matrix[0][j] == 0:
                row0_flag = True
                break
        # 第一列是否有0
        for i in range(row):
            if matrix[i][0] == 0:
                col0_flag = True
                break

        # 把第一行或者第一列作为 标志位
        for i in range(1, row):
            for j in range(1, col):
                if matrix[i][j] == 0:
                    matrix[i][0] = matrix[0][j] = 0
        #print(matrix)
        # 置0
        for i in range(1, row):
            for j in range(1, col):
                if matrix[i][0] == 0 or matrix[0][j] == 0:
                    matrix[i][j] = 0

        if row0_flag:
            for j in range(col):
                matrix[0][j] = 0
        if col0_flag:
            for i in range(row):
                matrix[i][0] = 0

相关推荐

  1. Leetcode 73 矩阵

    2024-03-09 23:38:06       36 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-09 23:38:06       91 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-09 23:38:06       97 阅读
  3. 在Django里面运行非项目文件

    2024-03-09 23:38:06       78 阅读
  4. Python语言-面向对象

    2024-03-09 23:38:06       88 阅读

热门阅读

  1. vue3 使用 mock 模拟服务器接口

    2024-03-09 23:38:06       49 阅读
  2. c++虚函数

    2024-03-09 23:38:06       54 阅读
  3. 【git】总结

    2024-03-09 23:38:06       39 阅读
  4. [R]To delete a dataset from the environment

    2024-03-09 23:38:06       49 阅读
  5. xml总结

    2024-03-09 23:38:06       41 阅读
  6. SQL 的优化手段

    2024-03-09 23:38:06       42 阅读
  7. 什么情况下导致索引失效

    2024-03-09 23:38:06       34 阅读
  8. Qt打开ROS工程文件

    2024-03-09 23:38:06       42 阅读
  9. 突破编程_C++_面试(单元测试)

    2024-03-09 23:38:06       44 阅读