【力扣100】73.矩阵置零

添加链接描述

class Solution:
    def setZeroes(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        # 思路是1.记录每一个0元素的行和列下标 2.遍历全数组
        row_index=[]
        column_index=[]
        m=len(matrix)
        n=len(matrix[0])
        # print(m,n)
        for i in range(m):
            for j in range(n):
                if matrix[i][j]==0:
                    row_index.append(i)
                    column_index.append(j)
        for i in range(m):
            for j in range(n):
                if(i in row_index or j in column_index):
                    matrix[i][j]=0

思路:

  1. 先扫一遍记录0
  2. 再扫一遍置0
  3. 时间复杂度就n*m太慢
  4. 空间复杂度是m+n


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. 先记录第一行第一列有无0
  2. 把第一行第一列作为标志位
  3. 空间变成o(1)
  4. 时间还是o(n*m)

相关推荐

  1. 100】73.矩阵

    2023-12-17 17:34:01       45 阅读
  2. 矩阵矩阵

    2023-12-17 17:34:01       36 阅读
  3. 73. 矩阵

    2023-12-17 17:34:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-17 17:34:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-17 17:34:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-17 17:34:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-17 17:34:01       18 阅读

热门阅读

  1. 复盘步骤| 每天,每周,每年

    2023-12-17 17:34:01       36 阅读
  2. 算法基础十五

    2023-12-17 17:34:01       29 阅读
  3. HashMap和Hashtable的区别(绝对经典)

    2023-12-17 17:34:01       37 阅读
  4. MapStruct

    2023-12-17 17:34:01       38 阅读
  5. 2312llvm,读写位码

    2023-12-17 17:34:01       42 阅读
  6. Using Implicit Rules

    2023-12-17 17:34:01       34 阅读
  7. WTN6040F-8S语音芯片:投篮游戏机新时代引领者

    2023-12-17 17:34:01       41 阅读