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

Posted 一杯敬朝阳一杯敬月光

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode - 学习计划之数据结构入门相关的知识,希望对你有一定的参考价值。

73. 矩阵置零

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

 

题解

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

class Solution(object):
    def setZeroes(self, matrix):
        """
        :type matrix: List[List[int]]
        :rtype: None Do not return anything, modify matrix in-place instead.
        """
        m, n = len(matrix), len(matrix[0])
        rows = [False] * m 
        cols = [False] * n 

        for i in range(m):
            for j in range(n):
                if matrix[i][j] == 0:
                    rows[i] = True 
                    cols[j] = True 
        
        for i in range(m):
            for j in range(n):
                if rows[i] or cols[j]:
                    matrix[i][j] = 0
        return None

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

class Solution(object):
    def setZeroes(self, matrix):
        m, n = len(matrix), len(matrix[0])
        # 用来记录第一行和第一列是否有0的标记
        row_flags = any([matrix[i][0]==0 for i in range(m)])
        col_flags = any([matrix[0][j]==0 for j in range(n)])

        for i in range(1, m):
            for j in range(1, n):
                # 其他位置有0,用第一行和第一列标记
                if matrix[i][j] == 0:
                    matrix[i][0] = 0 
                    matrix[0][j] = 0
        
        for i in range(1, m):
            for j in range(1, n):
                if matrix[i][0] == 0 or matrix[0][j] == 0:
                    matrix[i][j] = 0

        if row_flags:
            for i in range(m):
                matrix[i][0] = 0 
        if col_flags:
            for j in range(n):
                matrix[0][j] = 0
        return None

以上是关于leetcode - 学习计划之数据结构入门的主要内容,如果未能解决你的问题,请参考以下文章

leetcode - 学习计划之动态规划入门

leetcode - 学习计划之动态规划入门

[Leetcode]20天算法刷题计划之算法入门

[Leetcode]20天算法刷题计划之算法入门

leetcode - 学习计划之剑指offer

leetcode - 学习计划之剑指offer