LeetCode 热题 100 73. 矩阵置零

news/2025/2/23 22:46:12

LeetCode 热题 100 | 73. 矩阵置零

大家好,今天我们来解决一道经典的算法题——矩阵置零。这道题在LeetCode上被标记为中等难度,要求我们将矩阵中为0的元素所在的行和列全部置为0。下面我将分别给出非原地算法原地算法的Python代码实现,并进行对比分析。


问题描述

给定一个 m x n矩阵,如果一个元素为 0,则将其所在行和列的所有元素都设为 0

示例:

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

非原地算法代码

思路
  1. 使用两个额外的数组 rowscols 来记录需要置零的行和列。
  2. 遍历矩阵,记录所有值为 0 的元素所在的行和列。
  3. 根据记录的行和列,将矩阵中对应的行和列全部置为 0
代码实现
def setZeroes_non_inplace(matrix):
    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

# 测试示例
matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]

setZeroes_non_inplace(matrix1)
setZeroes_non_inplace(matrix2)

print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]

原地算法代码

思路
  1. 利用矩阵的第一行和第一列来标记需要置零的行和列。
  2. 需要额外处理第一行和第一列本身是否包含 0
代码实现
def setZeroes_inplace(matrix):
    m, n = len(matrix), len(matrix[0])
    first_row_has_zero = any(matrix[0][j] == 0 for j in range(n))
    first_col_has_zero = any(matrix[i][0] == 0 for i in range(m))

    # 使用第一行和第一列来标记是否需要置零
    for i in range(1, m):
        for j in range(1, n):
            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 first_row_has_zero:
        for j in range(n):
            matrix[0][j] = 0

    if first_col_has_zero:
        for i in range(m):
            matrix[i][0] = 0

# 测试示例
matrix1 = [[1,1,1],[1,0,1],[1,1,1]]
matrix2 = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]

setZeroes_inplace(matrix1)
setZeroes_inplace(matrix2)

print(matrix1)  # 输出: [[1,0,1],[0,0,0],[1,0,1]]
print(matrix2)  # 输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]

代码对比

非原地算法
  • 优点
    • 逻辑简单,易于理解和实现。
    • 不需要修改原始矩阵的额外信息。
  • 缺点
    • 使用了额外的空间 O(m + n) 来存储需要置零的行和列。
原地算法
  • 优点
    • 空间复杂度为 O(1),完全原地操作。
  • 缺点
    • 逻辑稍复杂,需要额外处理第一行和第一列。

总结

  • 非原地算法:逻辑简单,适合对空间复杂度要求不高的场景。
  • 原地算法:空间复杂度低,适合对空间要求严格的场景。

根据实际需求选择合适的方法即可。希望这篇题解对大家有所帮助,如果有任何问题,欢迎在评论区留言讨论!

关注我,获取更多算法题解和编程技巧!


http://www.niftyadmin.cn/n/5863839.html

相关文章

共筑金融数字化新生态!YashanDB与恒生电子完成兼容互认证

近日,深圳计算科学研究院的崖山数据库系统YashanDB与恒生电子股份有限公司HUNDSUN资产估值与会计核算软件V6.0成功完成了兼容性互认证。结果显示,双方产品完全兼容,稳定运行,可共同为银行、证券、基金、保险、信托等金融机构提供稳…

21.《SpringBoot 异步编程@Async与CompletableFuture》

SpringBoot 异步编程 文章导读 本文系统讲解 Spring Boot 异步编程的核心技术与实践方案,涵盖从基础使用到高级优化的全链路知识。通过深入剖析 Async 注解原理、线程池配置策略、异步异常处理机制等关键技术点,结合典型业务场景的代码示例&#xff0c…

【网络安全 | 漏洞挖掘】账户接管+PII+原漏洞绕过

文章目录 前言正文前言 本文涉及的所有漏洞测试共耗时约三周,成果如下: 访问管理面板,成功接管目标列出的3000多家公司。 获取所有员工的真实指纹、机密文件及个人身份信息(PII)。 绕过KYC认证,成功接管电话号码。 绕过此前发现的漏洞。 正文 在测试目标时,我发现了一…

chrome扩展程序如何实现国际化

先来看一个 manifest.json 文件的内容例子: { "update_url": "https://clients2.google.com/service/update2/crx ","default_locale": "en","name": "__MSG_appName__","short_name": &q…

lattice hdl实现spi接口

在lattice工具链中实现SPI接口通常涉及以下步骤: 定义硬件SPI接口的管脚。配置SPI时钟和模式。编写SPI主机或从机的控制逻辑。 展示了如何在Lattice工具链中使用HDL语言(例如Verilog)来配置SPI接口: lattice工程 顶层:spi_slave_top.v `timescale 1ns/ 1ps module spi_…

浅识Linux的DMA拷贝、MMAP映射与sendfile原理

Linux的DMA拷贝、MMAP映射与sendfile原理详解 1. DMA拷贝(Direct Memory Access) 原理: DMA(直接内存访问)是一种硬件机制,允许外设(如网卡、磁盘控制器)直接与内存交互&#xff0c…

Android studio如何把新项目上传到svn仓库

原文链接:1、Android studio svn上传新项目,2、Android Studio向SVN上传新项目 我在android studio上创建新项目,这项目名:MyApplication6 先看一下:TortoiseSVN\bin下的没有svn.exe的解决问题,把svn.ex…

第二章 基础知识(7) - 配置

注意 客户端上的用户可以看到配置和设置文件,用户可以篡改数据。 请勿在应用的配置或文件中存储应用机密、凭据或任何其他敏感数据使用 WebAssembly 或Auto模式时,请记住所有组件代码都会编译并发送到客户端,用户可以在客户端对其进行反向编…