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

10. 九转金丹炼矩阵 - 矩阵置零(标记优化)

哪吒在数据修仙界中继续他的修炼之旅。这一次,他来到了一片神秘的金丹谷,谷中有一座巨大的九转金丹炉,炉身闪烁着神秘的光芒。金丹炉的入口处有一块巨大的石碑,上面刻着一行文字:“欲破此炉,需以九转金丹之力,炼矩阵之零,标记优化定乾坤。”

哪吒定睛一看,石碑上还有一行小字:“矩阵中,需要将包含0的行和列全部置为0。”哪吒心中一动,他知道这是一道关于矩阵置零的难题,需要找到矩阵中所有包含0的行和列,并将它们全部置为0。

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

暴力解法:九转金丹的初次尝试

哪吒心想:“要将矩阵中包含0的行和列置为0,我可以先记录所有包含0的行和列,然后再逐行逐列置零。”他催动九转金丹之力,从头到尾遍历矩阵,用两个集合记录所有包含0的行和列。随后,他根据这些记录将对应的行和列置为0。

void setZeroes(vector<vector<int>>& matrix) {int m = matrix.size();int n = matrix[0].size();unordered_set<int> zeroRows, zeroCols;// 记录包含0的行和列for (int i = 0; i < m; ++i) {for (int j = 0; j < n; ++j) {if (matrix[i][j] == 0) {zeroRows.insert(i);zeroCols.insert(j);}}}// 置零行for (int row : zeroRows) {fill(matrix[row].begin(), matrix[row].end(), 0);}// 置零列for (int col : zeroCols) {for (int i = 0; i < m; ++i) {matrix[i][col] = 0;}}
}

哪吒成功地将矩阵中包含0的行和列置为0,但九转金丹炉的光芒却黯淡了下来。他意识到,这种方法虽然可行,但需要额外的空间来存储行和列的标记,灵力消耗较大。

C++语法点:集合与矩阵操作

在C++中,集合和矩阵操作是处理矩阵问题的常用工具。以下是一些重要特性:

  • 集合
    • unordered_set是一个基于哈希表的集合,用于存储唯一元素。
    • 常用方法:
      • insert(value):插入一个元素。
      • find(value):查找一个元素是否存在。
  • 矩阵操作
    • 使用vector<vector<int>>表示矩阵。
    • 使用fill(start, end, value)可以将一段范围内的元素全部置为指定值。

高阶优化:标记优化的智慧

哪吒元神中突然浮现金色铭文——「九转金丹炼,标记优化定乾坤」。他意识到,可以通过标记优化的方式,在矩阵的第一行

http://www.lryc.cn/news/542309.html

相关文章:

  • [实现Rpc] 客户端 | Requestor | RpcCaller的设计实现
  • Java 大视界 -- 深度洞察 Java 大数据安全多方计算的前沿趋势与应用革新(52)
  • 山东大学软件学院nosql实验三
  • 正态分布的奇妙性质:为什么奇数阶中心矩(odd central moments)为零?
  • 【入门音视频】音视频基础知识
  • 游戏引擎学习第120天
  • 【Qt之QQuickWidget】QML嵌入QWidget中
  • Vue 3 + Vite 项目中配置代理解决开发环境中跨域请求问题
  • Eureka、ZooKeeper 和 Nacos 之间的对比
  • CSS中padding和margin属性的使用
  • 【Python爬虫(49)】分布式爬虫:在新兴技术浪潮下的蜕变与展望
  • 网络安全-系统层攻击流程及防御措施
  • centos 7 安装python3 及pycharm远程连接方法
  • 【llm对话系统】如何快速开发一个支持openai接口的llm server呢
  • 跟着柳叶刀数字健康,学习如何通过病理切片预测分子分类对预后的影响|项目复现
  • deepseek_清华大学指导手册_pdf_1-5
  • 数据库(MySQL)二
  • 第15届 蓝桥杯 C++编程青少组中/高级选拔赛 202401 真题答案及解析
  • 《AI大模型趣味实战》第10集:开发一个基于Mermaid的AI绘图网站
  • androidstudio 运行项目加载很慢,优化方法
  • python脚本实现接入企微机器人
  • 《论面向对象的建模及应用》审题技巧 - 系统架构设计师
  • 【Godot4.3】自定义圆角容器
  • 开源RAG主流框架有哪些?如何选型?
  • 【Microsoft PowerPoint for Mac】2分钟配置-MAC一键删除PPT中的所有备注
  • 【UML】统一建模语言 UML 基础
  • AWS S3深度解析:十大核心应用场景与高可用架构设计实践
  • 如何用Python 3自动打开exe程序
  • 计算机网络之路由协议(自治系统)
  • MFC笔记:本专栏课件