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

【Swift】LeetCode 73. 矩阵置零

73. 矩阵置零

在这里插入图片描述

题目描述

在这里插入图片描述

思路与 Swift 题解

由于这道题目已经要求需要使用原地算法,因此性能最好的算法应该是使用额外空间占用最少的算法。

解决这道题目的时候需要注意的是,我们不能够简单地通过一次遍历二维数组,令nums[i][j] == 0的第i行和第j列为零。理由非常简单,如果nums[0][0] == 0,我们接下来设置第零行第零列为零,那么整个数组最终都将会被置零。

我们可以通过两次遍历来解决这个问题。首先,我们第一次遍历二维数组,找到那些为零的值,并使用一种方式来标记这一行和这一列将来要被置为零。在第二次,我们不需要遍历整个数组,只需要置那些被标记为零的行和列为零即可。

问题归结为,我们通过什么方式来标记一行和一列将要被置为零。一个朴素的方式是新开两个向量(数组),长度分别为mn,分别记录哪些行被标记为零以及哪些列被标记为零。该方式所占用的额外空间复杂度是m + n

更简单的方式是,我们直接利用原数组的第零行和第零列。首先,我们找第零行当中是否有零,如果有的话,使用一个布尔值记录该行最后需要被置为零;对列同理。然后,我们跳过第零行和第零列,遍历整个二维数组,如果遇到nums[i][j] == 0,就置nums[0][j] = nums[i][0] = 0。再然后,基于第零行和第零列,我们置第一行及之后的相应行以及第一列及之后的相应列为零。最后,基于我们一开始维护的两个布尔值,置第零行和第零列为零。

基于上述方式,我们使用两个布尔值的额外空间复杂度,解决了这道题目。

完整的 Swift 题解是:

class Solution {func setZeroes(_ matrix: inout [[Int]]) {var m = matrix.countvar n = matrix[0].countvar col = false, row = falsefor i in 0..<m {if matrix[i][0] == 0 {col = truebreak}}for j in 0..<n {if matrix[0][j] == 0 {row = truebreak}}for i in 1..<m {for j in 1..<n {if matrix[i][j] == 0 {matrix[i][0] = 0matrix[0][j] = 0}}}for i in 1..<m {if matrix[i][0] == 0 {for j in 1..<n {matrix[i][j] = 0}}}for j in 1..<n {if matrix[0][j] == 0 {for i in 1..<m {matrix[i][j] = 0}}}if row {for j in 0..<n {matrix[0][j] = 0}}if col {for i in 0..<m {matrix[i][0] = 0}}}
}
http://www.dtcms.com/a/540097.html

相关文章:

  • 益和热力性能优化实践:从 SQL Server 到 TDengine 时序数据库,写入快 20 秒、查询提速 5 倍
  • 蚂蚁集团已在香港申请「ANTCOIN」等 Web3 相关商标
  • HarmonyOS实战项目:开发一个分布式新闻阅读客户端
  • “Web3、区块链、稳定币”名词解析
  • 【参赛心得】鸿蒙三方库适配实战:从 Hadoop 生态到鸿蒙生态,企业级项目集成的 6 个最佳实践
  • 【SpringBoot】29 核心功能 - 数据访问 - Spring Boot 2 操作 Redis 实践指南:本地安装与阿里云 Redis 对比应用
  • B.40.3.1-Spring Boot与Spring Cloud核心技术详解
  • HarmonyOS RemoteWindow远程窗口组件的分布式能力深度解析
  • HarmonyOS自动化测试与持续集成实战指南
  • 智慧团建网站入口官网手机前端开发软件工具
  • 中国建设银行金华分行网站微信小程序在哪里找出来
  • Visual Basic 二进制文件
  • WEB前端技术基础(第四章:JavaScript-网页动态交互语言)
  • 房屋租赁合同中协助办证义务分析及租金退还法律意见
  • 广州住房和城乡建设厅网站网站建设 中企动力公司
  • 外贸网站空间哪个好WordPress首页id
  • STM32F407移植FreeRTOS完整教程(HAL库版本)
  • Flink 并行度与最大并行度从 0 到弹性扩缩容
  • STL list深度解析:从原理到手写实现
  • AI驱动数据分析革新:奥威BI一键生成智能报告
  • day20_权限控制
  • Flutter 状态管理详解:深入理解与使用 Bloc
  • Spring Boot 移除 Undertow 深度解析:技术背景、迁移方案与性能优化实践
  • c# stateless介绍
  • 烽火台网站网站优化要从哪些方面做
  • 建设一个网站需要多少钱网页版游戏在线玩2022
  • 基于Flask的穷游网酒店数据分析系统(源码+论文+部署+安装)
  • Linux系统--线程的同步与互斥
  • 智慧校园顶层设计与规划方案PPT(71页)
  • 滨州网站建设费用学校网站管理系统 php