• leetcode - 学习计划之数据结构入门


    73. 矩阵置零

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

     

    题解

    一:用两个数组分别记录行和列是否有零,空间复杂度O(m+n),时间复杂度O(m*n)。

    1. class Solution(object):
    2. def setZeroes(self, matrix):
    3. """
    4. :type matrix: List[List[int]]
    5. :rtype: None Do not return anything, modify matrix in-place instead.
    6. """
    7. m, n = len(matrix), len(matrix[0])
    8. rows = [False] * m
    9. cols = [False] * n
    10. for i in range(m):
    11. for j in range(n):
    12. if matrix[i][j] == 0:
    13. rows[i] = True
    14. cols[j] = True
    15. for i in range(m):
    16. for j in range(n):
    17. if rows[i] or cols[j]:
    18. matrix[i][j] = 0
    19. return None

    二、将空间复杂度将为O(1),用第一行来记录对应列中是否有0,若有第一行对应列记0(反正最后也是要变成0的,此处值的先改变不影响),用第一列来记录对应行中是否有0,若有第一列对应行记为0。只不过这样我们就改变了第一行和第一列的值,我们无法标记第一行是否有0,第一列是否有0,所以先用两个变量做个标记。第二次便利,若第一行或第一列对应位置有0,则该位置为0,最后按两个标记处理第一行和第一列。

    1. class Solution(object):
    2. def setZeroes(self, matrix):
    3. m, n = len(matrix), len(matrix[0])
    4. # 用来记录第一行和第一列是否有0的标记
    5. row_flags = any([matrix[i][0]==0 for i in range(m)])
    6. col_flags = any([matrix[0][j]==0 for j in range(n)])
    7. for i in range(1, m):
    8. for j in range(1, n):
    9. # 其他位置有0,用第一行和第一列标记
    10. if matrix[i][j] == 0:
    11. matrix[i][0] = 0
    12. matrix[0][j] = 0
    13. for i in range(1, m):
    14. for j in range(1, n):
    15. if matrix[i][0] == 0 or matrix[0][j] == 0:
    16. matrix[i][j] = 0
    17. if row_flags:
    18. for i in range(m):
    19. matrix[i][0] = 0
    20. if col_flags:
    21. for j in range(n):
    22. matrix[0][j] = 0
    23. return None

  • 相关阅读:
    Spark - 第20章 流处理基础
    vue3的ref全家桶---kalrry---ing
    (C语言进阶)设计模式之--观察者模式
    通信原理_2 确定信号分析
    Spring boot 随笔 1 DatasourceInitializer
    GCC版本升级到指定版本
    KNN-KG论文学习笔记
    【数据结构】链表超全整理~
    Java8-Optional工具类(有效防止空指针异常)
    Linux --- 传输层 | UDP
  • 原文地址:https://blog.csdn.net/qq_xuanshuang/article/details/126128730