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

LeetCode 第73题:矩阵置零

给定一个m*n的矩阵,如果一个元素为0,则将其所在行和列的所有元素都设为0,请使用原地算法。(在计算机科学中,一个原地算法(in-place algorithm)是一种使用小的,固定数量的额外之空间来转换资料的算法。当算法执行时,输入的资料通常会被要输出的部分覆盖掉。不是原地算法有时候称为非原地(not-in-place)或不得其所(out-of-place)。)

示例1:

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

示例2:

输入:matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
输出:[[0,0,0,0],[0,4,5,0],[0,3,1,0]]

提示:

  • m == matrix.length
  • n == matrix[0].length
  • 1 <= m, n <= 200
  • -2的31次 <= matrix[i][j] <= 2的31次 - 1

进阶:

  • 一个直观的解决方案是使用  O(mn) 的额外空间,但这并不是一个好的解决方案。
  • 一个简单的改进方案是使用 O(m + n) 的额外空间,但这仍然不是最好的解决方案。
  • 你能想出一个仅使用常量空间的解决方案吗?

解题思路:

使用两个标记数组分布记录每一行和每一列是否有零出现。

 首先遍历该数组一次,如果某个元素为0,那么就将该元素所在的行和列所对应标记数组的位置置为true。最后再次遍历该数组,用标记数组更新原数组。

void setZeroes(int** matrix, int matrixSize, int* matrixColSize) {int m = matrixSize,n=matrixColSize[0],row[m],col[n];memset(row,0,sizeof(row));memset(col,0,sizeof(col));for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(!matrix[i][j])  row[i]=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;
}

时间复杂度:O(mn),其中 m 是矩阵的行数,n 是矩阵的列数。我们至多只需要遍历该矩阵两次。

空间复杂度:O(m+n),其中 m 是矩阵的行数,n 是矩阵的列数。我们需要分别记录每一行或每一列是否有零出现。

相关文章:

  • EngineAI 1. Start/Resume Training
  • 1.1 Linux 编译FFmpeg 4.4.1
  • Git详解:初学者完全指南
  • Git 工作流与版本管理策略
  • 日本生活:日语语言学校-日语作文-沟通无国界(1)-题目:假装写日记
  • YOLOv8分类的三种C++实现:opencv dnn/libtorch/onnxruntime
  • java 设计模式_行为型_16访问者模式
  • 深入解析ArrayList源码:从短链项目实战到底层原理
  • 2025年EAAI SCI1区TOP,贪婪策略粒子群算法GS-IPSO+无人机桥梁巡检覆盖路径规划,深度解析+性能实测
  • 【项目实训#08】HarmonyOS知识图谱前端可视化实现
  • 计算机网络-自顶向下—第一章概述重点复习笔记
  • XMLDecoder、LDAP 注入与修复
  • WebSocket与XMPP:即时通讯技术的本质区别与选择逻辑优雅草卓伊凡|片翼|许贝贝
  • [每周一更]-(第147期):使用 Go 语言实现 JSON Web Token (JWT)
  • 深度学习——基于卷积神经网络的MNIST手写数字识别详解
  • 大规模异步新闻爬虫的分布式实现
  • 【Jmeter】Jmeter 高并发性能压力测试
  • orb_slam--安装配置
  • 混合云战略规划深度解析:多云管理的技术架构与治理框架
  • (题目向,随时更新)动态规划算法专题(2) --见识常见的尝试模型
  • 网站服务器搭建的步骤/上海有哪些优化网站推广公司
  • 做网站团队的人员安排/企业网站开发制作
  • 如何看网站空间问题/seo站内优化培训
  • 重庆网站制作的网站/seo是什么职位缩写
  • 网站顶端图片素材/竞价外包推广
  • 网站建设 中企动力西安/如何用模板建站