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

免费涨1000粉丝网站多语言建设外贸网站

免费涨1000粉丝网站,多语言建设外贸网站,wordpress 常规选项,wordpress主题设置插件下载这是一道难度为中等的题目&#xff0c;让我们来看看题目描述&#xff1a; 给定一个 _m_ x _n_ 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 提示&#xff1a; m matrix.lengthn matrix[0].length1 < m, n …

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

给定一个 _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。
  • 这样就符合题目的要求,用 两次遍历 实现 原地置零
http://www.dtcms.com/a/435108.html

相关文章:

  • 做外贸的网站平台有哪些网站网页设计代码
  • 深入了解linux网络—— 基于UDP实现翻译和聊天功能
  • 基于高斯函数傅里叶变换的函数傅里叶变换求解(含多项式与三角函数项)
  • 2025,跨领域发展的低门槛技能切入路径
  • 如何通过UKey实现文件加密?——基于硬件密钥的端到端数据保护实战指南
  • 公司建的站加油违法吗网站设计知名企业
  • 张家界网站制作与代运营常州微信网站建设
  • 电影网站建设哪家便宜深圳市做网站公司
  • 实战破解前端渲染:当 Requests 无法获取数据时(Selenium/Playwright 入门)
  • 如何建立小企业网站论坛源码哪个好
  • 网站建设摊销时间是多久seo咨询服务
  • 精细化工企业安全运营:危化品投料记录与反应釜压力实时监控方案
  • 网站的ftp信息推广公司哪里找
  • 【精品资料鉴赏】384页WORD版小学智慧校园项目建设初步设计方案
  • 手机移动网站建设怎么把网站放到服务器
  • 《牛刀小试!C++ string类核心接口实战编程题集》
  • 做视频网站资源采集软件app定制开发
  • 【原创】SpringBoot3+Vue3商品信息管理系统
  • 3 阐述网站建设的步骤过程哪种网站开发简单
  • Spring Boot 热部署配置与自定义排除项
  • B007基于博途西门子1200PLC四节传送带控制系统仿真
  • C++11新特性解析与应用(1)
  • 【LangChain】P7 对话记忆完全指南:从原理到实战(下)
  • 上海建设房屋网站下载好了网站模板怎么开始做网站
  • 远程智能康养实训室:训练学生驾驭物联网,服务未来居家康养新时代
  • ⚡ WSL2 搭建 s5p6818 Linux 嵌入式开发平台(part 1):环境准备与架构设计
  • 学科建设网站wordpress 主体安装
  • 如何免费建立自己的网站中国建设摩托车
  • 主机服务器网站 怎么做孝义网站建设
  • 快速搭建企业网站阿里虚拟机建设网站