当前位置: 首页 > article >正文

LeetCode hot 100 每日一题(13)——73. 矩阵置零

这是一道难度为中等的题目,让我们来看看题目描述:

给定一个 _m_ x _n_ 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。
在这里插入图片描述

提示:

  • m == matrix.length
  • n == matrix[0].length
  • 1 <= m, n <= 200
  • - 2 31 2^{31} 231 <= matrix[i][j] <= 2 31 2^{31} 231 - 1

题解

class Solution {public void setZeroes(int[][] matrix) {int m = matrix.length;  // 获取矩阵的行数int n = matrix[0].length; // 获取矩阵的列数boolean[] row = new boolean[m]; // 记录需要置零的行boolean[] col = new boolean[n]; // 记录需要置零的列// 第一遍遍历矩阵,标记所有含有 0 的行和列for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){if(matrix[i][j] == 0){ row[i] = true;  // 标记该行需要置零col[j] = true;  // 标记该列需要置零}}}// 第二遍遍历矩阵,根据标记的行和列将相应元素置零for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){if(row[i] || col[j]){ // 如果当前行或列被标记为需要置零matrix[i][j] = 0; // 置零操作}}}}
}

解题思路

1. 题目分析

给定一个 m × n 的矩阵,如果某个元素为 0,则需要将它所在的整行和整列的所有元素都设为 0。要求在原矩阵上直接修改,不能使用额外的矩阵存储修改后的数据。

2. 解法思路

  • 第一步:标记所有需要置零的行和列

    • 用两个数组 row[]col[] 分别记录哪些需要置零。

    • 遍历矩阵,如果遇到 matrix[i][j] == 0,就将 row[i]col[j] 标记为 true,表示该行或该列需要全部置零。

  • 第二步:遍历矩阵,根据标记进行置零

    • 再次遍历矩阵,如果 row[i]truecol[j]true,说明该位置 matrix[i][j] 需要置零。

3. 复杂度分析

  • 时间复杂度:O(m × n)

    • 需要两次遍历整个矩阵,时间复杂度为 O(m × n),符合题目要求。
  • 空间复杂度:O(m + n)

    • 额外使用了 row[]col[] 两个数组,空间复杂度为 O(m + n)

4. 进阶优化

如果希望减少额外空间使用,可以利用矩阵的第一行和第一列来存储这些标记,而不使用额外的 row[]col[] 数组,进而将空间复杂度优化为 O(1)

问题与解答

[NOTE] 问题1:
if(row[i] || col[j])这一句我有一点不懂,为什么要么行或列被标记,就会被置0呢?
解答:
这个 if(row[i] || col[j]) 条件的作用是:如果当前元素所在的行 i 或列 j 需要置零,则将该元素 matrix[i][j] 置为 0


为什么这样判断?

想象一下矩阵的置零规则:

  • 如果一个元素 matrix[i][j] == 0,那么它所在的整行整列 都要变成 0
  • 在第一遍遍历矩阵时,我们用 row[i] 记录i 行是否需要全部变 0,用 col[j] 记录j 列是否需要全部变 0
  • 因此,在第二遍遍历时:
    • 如果 row[i] == true,说明该行有一个元素原本是 0,所以整行要变 0,当前元素 matrix[i][j] 也必须变 0
    • 如果 col[j] == true,说明该列有一个元素原本是 0,所以整列要变 0,当前元素 matrix[i][j] 也必须变 0
    • 只要满足任意一个条件 (row[i]col[j]),当前元素 matrix[i][j] 必须变成 0

举例分析

示例 1

输入矩阵:

[[1, 1, 1],[1, 0, 1],[1, 1, 1]
]

第一遍标记 row[]col[]

row = [false, true, false]  // 第 1 行(索引 1)需要置零
col = [false, true, false]  // 第 1 列(索引 1)需要置零

第二遍遍历并置零(应用 if(row[i] || col[j])

[[1, 0, 1],  // 因为 col[1] = true,第二列所有元素变 0[0, 0, 0],  // 因为 row[1] = true,整行变 0[1, 0, 1]   // 因为 col[1] = true,第二列所有元素变 0
]

总结

  • row[i] 记录行是否要变 0col[j] 记录列是否要变 0
  • if(row[i] || col[j]) 的含义是:
    • 如果这一行之前有 0,则当前行的所有元素都要变 0
    • 如果这一列之前有 0,则当前列的所有元素都要变 0
    • 如果当前行或列任意一个需要变 0,那么 matrix[i][j] 也必须变 0。
  • 这样就符合题目的要求,用 两次遍历 实现 原地置零

相关文章:

LeetCode hot 100 每日一题(13)——73. 矩阵置零

这是一道难度为中等的题目&#xff0c;让我们来看看题目描述&#xff1a; 给定一个 _m_ x _n_ 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 提示&#xff1a; m matrix.lengthn matrix[0].length1 < m, n …...

CEF 给交互函数, 添加控制台是否显示交互参数log开关

CEF 控制台添加一函数,枚举 注册的供前端使用的CPP交互函数有哪些 CEF 多进程模式时,注入函数,获得交互信息-CSDN博客 这两篇文章,介绍了注入函数,在控制台中显示 各自提供的交互函数信息。 有些场景下,我们还需要更详细的信息,比如想知道 彼此传递的参数, 如果每次调…...

云端存储新纪元:SAN架构驱动的智能网盘解决方案

一、企业存储的"不可能三角"破局 1.1 传统存储架构的困局 性能瓶颈&#xff1a;NAS架构在1000并发访问时延迟飙升300%容量限制&#xff1a;传统RAID扩容需停机维护&#xff0c;PB级存储扩展耗时超48小时成本矛盾&#xff1a;全闪存阵列每TB成本高达$3000&#xff0…...

PVE 安装黑苹果 MacOS

背景 我需要一台黑苹果&#xff0c;登录我不常用苹果账号。 方法 The Definitive Guide to Running MacOS in ProxmoxRunning a MacOS 15 Sequoia VM in ProxMox VE及视频 按照第二个的视频一步一步配置&#xff0c;第一个链接提供了不同版本OS...

Unity URP自定义Shader支持RenderLayer

前言&#xff1a; 当我们想用一个灯光只对特定的物体造成影响&#xff0c;而不对其余物体造成影响时&#xff0c;我们就需要设置相对应的LightLayer&#xff0c;但是这在URP12.0是存在的&#xff0c;在之后就不存在LightLayer这一功能&#xff0c;URP将其隐藏而改成了RenderLa…...

Axure项目实战:智慧城市APP(完整交互汇总版)

亲爱的小伙伴&#xff0c;在您浏览之前&#xff0c;烦请关注一下&#xff0c;在此深表感谢&#xff01; 课程主题&#xff1a;智慧城市APP 主要内容&#xff1a;主功能&#xff08;社保查询、医疗信息、公交查询等&#xff09;、活动、消息、我的页面汇总 应用场景&#xff…...

LVS-DR模式配置脚本

LVS-DR模式配置脚本 实验环境&#xff0c;需要4台虚拟机 IP说明172.25.254.101客户端172.25.254.102负载均衡器DS172.25.254.103真实服务器RS172.25.254.104真实服务器RSVIP&#xff1a;172.25.254.255/32 系统必须有ipvsadm和ifconfig命令 dnf install ipvsadm dnf install n…...

树状数组 3 :区间修改,区间查询

【题目描述】 这是一道模板题。 给定数列 a[1],a[2],…,a[n]&#xff0c;你需要依次进行q个操作&#xff0c;操作有两类&#xff1a; 1lrx&#xff1a;给定 l,r,x对于所有 i∈[l,r]&#xff0c;将a[i]加上x&#xff08;换言之&#xff0c;将 a[l],a[l1],…a[r] 分别加上 x&a…...

架构思维:预约抢茅子架构设计

文章目录 案例&#xff1a;预约抢茅子复杂度分析商品预约阶段等待抢购阶段商品抢购阶段订单支付阶段 技术方案商品预约阶段一、基于 Redis 单节点的分布式锁方案1. 核心流程2. 关键设计点 二、Redis 单节点方案的局限性1. 单点故障风险2. 主从切换问题 三、多节点 Redis 实现高…...

使用 gone.WrapFunctionProvider 快速接入第三方服务

项目地址&#xff1a;https://github.com/gone-io/gone 本文中源代码&#xff1a; esexamples/es 文章目录 1. gone.WrapFunctionProvider 简介2. 配置注入实现3. 实战示例&#xff1a;Elasticsearch 集成4. 使用方式5. 最佳实践6. 总结 在如何给Gone框架编写Goner组件&#xf…...

基于SpringBoot+Vue的在教务管理(课程管理)系统+LW示例

1.项目介绍 系统角色&#xff1a;管理员、学生、教师功能模块&#xff1a;管理员&#xff08;学院管理、专业管理、班级管理、学生管理、教师管理、课程管理、选课修改&#xff09;、教师&#xff08;授课查询、教师课表、成绩录入&#xff09;、学生&#xff08;选修课程、学…...

gitee 常用指令

1.拉取代码 // http git clone http.........// https git clone https......... 2. 设置自己账户和密码 ----- 绑定git git config --global user.name "你的用户名"git config --global user.email "你的邮箱" 3. 上传本地代码至git git initgit r…...

etcd性能测试

etcd性能测试 本文参考官方文档完成etcd性能测试&#xff0c;提供etcd官方推荐的性能测试方案。 1. 理解性能&#xff1a;延迟与吞吐量 etcd 提供稳定、持续的高性能。有两个因素决定性能&#xff1a;延迟和吞吐量。延迟是完成一项操作所花费的时间。吞吐量是在某个时间段内…...

JIRA/Xray测试管理工具的最佳实践:从基础到高阶的全场景指南

引言&#xff1a;测试管理的数字化转型与工具价值 在数字化时代&#xff0c;软件质量已成为企业竞争力的核心指标。然而&#xff0c;传统的测试管理方式——如Excel记录用例、邮件沟通缺陷、手动执行回归测试——已无法满足快速迭代的敏捷开发需求。据统计&#xff0c;全球因测…...

ubuntu桌面图标异常——主目录下的所有文件(如文档、下载等)全部显示在桌面

ubuntu桌面图标异常 问题现象问题根源系统级解决方案方法一:全局修改(推荐多用户环境)方法二:单用户修改(推荐个人环境)操作验证与调试避坑指南扩展知识参考文档问题现象 主目录文件异常显示 用户主目录(如/home/user/)下的所有文件(如文档、下载等)全部显示在桌面,…...

AIP-191 文件和目录结构

编号191原文链接https://google.aip.dev/191状态批准创建日期2019-07-25更新日期2019-07-25 统一的文件和目录结构&#xff0c;虽然在技术上差别不大&#xff0c;但可以让用户和审查者更容易阅读API界面定义。 指南 注意 以下指南适合于使用protobuf定义的API&#xff0c;例如…...

sql结尾加刷题

找了一下mysql对extractvalue()、updatexml()函数的官方介绍https://dev.mysql.com/doc/refman/5.7/en/xml-functions.html#function_extractvalue ExtractValue(xml_frag, xpath_expr) 知识点 解释一下这两个参数xml_frag&#xff0c;是xml标记片段&#xff0c;第二个参数…...

Linux学习笔记(应用篇三)

基于I.MX6ULL-MINI开发板 LED学习GPIO应用编程输入设备 开发板中所有的设备&#xff08;对象&#xff09;都会在/sys/devices 体现出来&#xff0c;是 sysfs 文件系统中最重要的目录结构 /sys下的子目录说明/sys/devices这是系统中所有设备存放的目录&#xff0c;也就是系统中…...

LLM动态Shape实现原理与核心技术

LLM动态Shape实现原理与核心技术 目录 LLM动态Shape实现原理与核心技术1. **动态Shape核心原理**2. **实现方法与关键技术**3. **示例:vLLM处理动态长度输入**4. **动态Shape vs 静态Shape对比**5. **性能优化案例**总结`SamplingParams` 是什么常见参数及作用使用示例1. 动态…...

MyBatis 语法不支持 having 节点

MyBatis 不支持 having 节点 比如在 GROUP BY 之后添加了 HAVING 子句&#xff0c;其内容为SUM(vsbsad.business_income) > 0&#xff0c;该子句会对分组后的 SUM(vsbsad.business_income) 结果进行过滤&#xff0c;仅保留求和结果不为负数的分组记录。但是试过不支持。可把…...

【redis】事务详解,相关命令multi、exec、discard 与 watch 的原理

文章目录 什么是事务原子性一致性持久性隔离性 优势与 MySQL 对比用处 事务相关命令开启事务——MULTI执行事务——EXEC放弃当前事务——DISCARD监控某个 key——WATCH作用场景使用方法实现原理 事务总结 什么是事务 MySQL 事务&#xff1a; 原子性&#xff1a;把多个操作&am…...

数据库基础知识点(系列七)

视图和索引相关的语句 1&#xff0e;引入视图的主要目的是什么? 答&#xff1a;数据库的基本表是按照数据库设计人员的观点设计的&#xff0c;并不一定符合用户的需求。SQL Server 2008可以根据用户需求重新定义表的数据结构&#xff0c;这种数据结构就是视图。视图是关系数据…...

FreeRTOS 队列结构体 xQUEUE 深度解析

一、核心成员与功能设计 FreeRTOS 的队列结构体 xQUEUE 是任务间通信&#xff08;IPC&#xff09;的核心数据结构&#xff0c;通过统一的设计支持队列、信号量、互斥量等多种同步机制。其设计体现了 ​**"数据拷贝 结构复用"** 的理念&#xff0c;兼顾轻量化与扩展…...

3.3 Taylor公式

1.定义 1.1 taylor公式 1.2 麦克劳林公式 1.3 推论 1.4 拉格朗日余项和皮亚诺型余项 2. 例题 3.几种特殊函数的麦克劳林展开...

2000-2019年各省地方财政行政事业性收费收入数据

2000-2019年各省地方财政行政事业性收费收入数据 1、时间&#xff1a;2000-2019年 2、来源&#xff1a;国家统计局、统计年鉴 3、指标&#xff1a;行政区划代码、地区、年份、地方财政行政事业性收费收入 4、范围&#xff1a;31省 5、指标说明&#xff1a;地方财政行政事业…...

Ftrans飞驰云联受邀参加“2025汽车零部件CIO年会“并荣获智象奖

2025年3月6日&#xff0c;由栖观汽车、栖观资讯和飞羽商务主办的“2025第二届中国汽车&零部件CIO年会暨智象奖颁奖盛典”于上海盛大召开&#xff0c;Ftrans飞驰云联作为国内领先的企业文件传输与数据交换解决方案提供商&#xff0c;受邀出席了年会&#xff0c;并凭借卓越的…...

C++vector常用接口和模拟实现

C中的vector是一个可变容量的数组容器&#xff0c;它可以像数组一样使用[]进行数据的访问&#xff0c;但是又不像C语言数组空间是静态的&#xff0c;它的空间是动态可变的。 在日常中我们只需要了解常用的接口即可&#xff0c;不常用的接口查文档即可。 1.构造函数 //空构造…...

oracle查询归档日志使用量

1.统计最近30天的数据 SELECT TRUNC(first_time, DD) "日期", SUM(blocks * block_size) / 1024 / 1024 / 1024 "大小(GB)" FROM v$archived_log WHERE first_time > SYSDATE - 30 -- 统计最近30天的数据 GROUP BY TRUNC(first_time, DD) ORDER BY 1 D…...

计算机二级WPS Office第七套WPS演示

解题过程...

2025-03-26 学习记录--C/C++-PTA 6-3 求链式表的表长

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、题目描述 ⭐️ 6-3 求链式表的表长 本题要求实现一个函数&#xff0c;求链式表的表长。 函数接口定义&#xff1a; &…...