静态摄影网站模板/百度北京分公司官网

静态摄影网站模板,百度北京分公司官网,无锡本地做网站,什么叫网站建设和维护这是一道难度为中等的题目&#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.mzph.cn/news/898692.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java基础编程练习第34题-正则表达式

在Java里&#xff0c;正则表达式是一种强大的文本处理工具&#xff0c;它可以用于字符串的搜索、替换、分割和校验等操作。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。Java通过java.util.regex包提供了对正则表达式的支持。 以下是正则表达式在Jav…

基于基于eFish-SBC-RK3576工控板的智慧城市边缘网关

此方案充分挖掘eFish-SBC-RK3576的硬件潜力&#xff0c;可快速复制到智慧园区、交通枢纽等场景。 方案亮点 ‌接口高密度‌&#xff1a;单板集成5GWiFi多路工业接口&#xff0c;减少扩展复杂度。‌AIoT融合‌&#xff1a;边缘端完成传感器数据聚合与AI推理&#xff0c;降低云端…

redis解决缓存穿透/击穿/雪崩

文章目录 1.缓存穿透1.1 概念1.2 解决方案1.2.1 缓存空对象1.2.2 布隆过滤 1.2 店铺查询使用缓存穿透解决方案1.2.1 流程 2.缓存雪崩2.1 什么是缓存雪崩&#xff1f;2.2 雪崩解决方案 3.缓存击穿3.1 什么是缓存击穿&#xff1f;3.2解决方案3.2.1 基于互斥锁解决缓存击穿问题&am…

第十六届蓝桥杯康复训练--6

题目链接&#xff1a;790. 数的三次方根 - AcWing题库 思路&#xff1a;二分&#xff0c;注意正负号和小数判断退出的方法&#xff08;虽然正负无所谓&#xff09; 代码&#xff1a; #include<bits/stdc.h> using namespace std;#define exs 0.00000018812716007232667…

【AVRCP】深度剖析 AVRCP 中 Generic Access Profile 的要求与应用

目录 一、GAP基础架构与核心要求 1.1 GAP在蓝牙体系中的定位 1.2 核心模式定义 二、AVRCP对GAP的增强要求 2.1 模式扩展规范 2.2 空闲模式过程支持 三、安全机制实现细节 3.1 认证与加密流程 3.2 安全模式要求 四、设备发现与连接建立 4.1 发现过程状态机 4.2 连接…

DeepSeek和Kimi在Neo4j中的表现

以下是2个最近爆火的人工智能工具&#xff0c; DeepSeek:DeepSeek Kimi: Kimi - 会推理解析&#xff0c;能深度思考的AI助手 1、提示词&#xff1a; 你能帮我生成一个知识图谱吗&#xff0c;等一下我会给你一篇文章&#xff0c;帮我从内容中提取关键要素&#xff0c;然后以N…

相机光学中一些疑难问题的解释

工业机器视觉系统广泛应用于自动化生产、质量控制、物体检测等领域&#xff0c;而光学原理和镜头选择是确保其精准度和高效性的关键因素。 1. 为什么镜头的最大光圈处通常成像不佳&#xff1f; 在许多摄影场景中&#xff0c;最大光圈&#xff08;例如F1.2、F1.8&#xff09;是…

蓝桥杯高频考点——并查集(心血之作)

并查集 TA Can Do What & why learningwhatwhy 原理和结构路径压缩例题讲解题解solution 1&#xff08;50分&#xff09;solution 2&#xff08;100分&#xff09; 按秩(树高)合并按大小合并 TA Can Do What & why learning what 并查集主要是解决连通块的问题&#x…

简单实用!百度AI + Raphael AI = 免费生图

简单实用&#xff01;百度AI Raphael AI 免费生图 -- ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/b55eda9141d34697b05db0cd60f62b75.png#pic_center) 第一步&#xff1a;下载或截取一些好看的图片当参考图片 第二步&#xff1a;用百度AI描述你想要的图片&…

React中组件通讯与插槽

一、为DOM组件设置Props 1.用JSX语法对标签的类名进行设置属性名是className&#xff1b; 2.用JSX语法对标签的样式进行设置要使用键值对进行设置&#xff0c;带“-”时用小驼峰方法来书写&#xff1b; 3.当一个标签的属性过多时&#xff0c;可以通过JSX语法进行展开设置&am…

自定义reset50模型转换到昇腾om

目录 原始转换脚本 脚本运行报错 基于reset50 模型的自定义网络 基本网络结构 卷积模块定义示例 Bottleneck定义示例 网络定义示例 改进的转换脚本 脚本运行报错channels不匹配 脚本运行报错维度不匹配 模型输入数据的类型 tensor size NCHW和NHWC 自定义网络的通…

vue3:十一、主页面布局(进入指定菜单页面,默认锁定到左侧菜单)

一、效果 直接进入home页面&#xff0c;直接展开对应的菜单项 二、具体实现 1、菜单容器增加默认选中变量 在菜单容器中将默认展开菜单default-openeds修改为默认选中菜单default-active 2、引入useRoute方法 引入该方法为了获取当前页面的路径 import { useRoute } from …

六十天前端强化训练之第二十七天之Pinia 状态管理全解与购物车实战案例

欢迎来到编程星辰海的博客讲解 看完可以给一个免费的三连吗&#xff0c;谢谢大佬&#xff01; 目录 一、Pinia 深度解析 1. Pinia 核心设计 2. 核心概念图解 3. Store 类型对比 Option Store&#xff08;选项式&#xff09; Setup Store&#xff08;组合式&#xff09; …

Java多线程与高并发专题——Future 是什么?

引入 在上一篇Callable 和 Runnable 的不同&#xff1f;的最后&#xff0c;我们有提到和 Callable 配合的有一个 Future 类&#xff0c;通过 Future 可以了解任务执行情况&#xff0c;或者取消任务的执行&#xff0c;还可获取任务执行的结果&#xff0c;这些功能都是 Runnable…

用ArcGIS做一张符合环评要求的植被类型图

植被类型图是环境影响评价&#xff08;环评&#xff09;中的重要图件&#xff0c;需满足数据准确性、制图规范性和信息完整性等要求。本教程将基于ArcMap平台&#xff0c;从数据准备到成果输出&#xff0c;详细讲解如何制作符合环评技术规范的植被类型图。 ArcGIS遥感解译土地…

Fourier-Lerobot——把斯坦福人形动作策略iDP3封装进了Lerobot(含我司七月人形研发落地实践)

前言 近期在抠lerobot源码时&#xff0c;看到其封装了ALOHA ACT、diffusion policy、π0时&#xff0c;我就在想&#xff0c;lerobot其实可以再封装下idp3 我甚至考虑是否从我联合带的那十几个具身研究生中选几个同学做下这事&#xff0c;对他们也是很好的历练然当25年3.18日…

MySQL拒绝访问

1. 问题 使用图形界面工具连接MySQL数据库&#xff0c;拒绝访问&#xff01; 2. 解决方法 以管理员的身份打开cmd&#xff0c;输入命令&#xff0c;启动MySQL net start mysql版本号 3. 参考 暂无

多模态SVG生成新标杆:StarVector从图像文本生成高精度SVG的AI模型

一、引言&#xff1a;矢量图形的崛起与挑战 在现代数字世界中&#xff0c;图像扮演着至关重要的角色&#xff0c;而可伸缩矢量图形&#xff08;SVG&#xff09;正因其独特的优势&#xff0c;在网页设计、图形设计等领域占据着越来越重要的地位。与传统的基于像素的栅格图像不同…

Netty——BIO、NIO 与 Netty

文章目录 1. 介绍1.1 BIO1.1.1 概念1.1.2 工作原理1.1.3 优缺点 1.2 NIO1.2.1 概念1.2.2 工作原理1.2.3 优缺点 1.3 Netty1.3.1 概念1.3.2 工作原理1.3.3 优点 2. Netty 与 Java NIO 的区别2.1 抽象层次2.2 API 易用性2.3 性能优化2.4 功能扩展性2.5 线程模型2.6 适用场景 3. 总…

游戏引擎学习第175天

回顾和今天的计划 今天的主要任务是完成稀疏 Unicode 支持。之前我们已经完成了所有的思考和设计工作&#xff0c;但代码部分尚未完成&#xff0c;因为有许多内容需要调整和重构。因此&#xff0c;今天的目标就是把这些内容全部整理好并最终实现。 回顾当前测试资源构建器的状…