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

力扣热门100题之矩阵置零

这道题要求不能用额外空间,必须用矩阵第一行、第一列当作标记位,是面试高频题!

核心思路(原地算法)

  1. 用第一行、第一列本身记录哪些行、哪些列需要置 0
  2. 先单独判断第一行、第一列本身是否有 0
  3. 遍历其他元素,遇到 0 就标记到第一行对应列第一列对应行
  4. 根据标记把对应行、列置 0
  5. 最后处理第一行、第一列

超级通俗大白话解释

1. 为什么要单独标记第一行、第一列?

因为第一行、第一列要用来当标记位,不能先把它们直接置 0,否则会丢失原本的标记信息。

2. 核心标记规则

  • 如果matrix[i][j] = 0
  • 就让第一行第 j 列 = 0(表示这一列要清零)
  • 就让第 i 行第一列 = 0(表示这一行要清零)

3. 最后清零

  • 看第一列 → 哪行标 0 → 整行清零
  • 看第一行 → 哪列标 0 → 整列清零
  • 最后根据一开始记录的firstRowfirstCol清零第一行、第一列

完整代码实现

class Solution { public void setZeroes(int[][] matrix) { int m = matrix.length; // 行数 int n = matrix[0].length; //列数 // 标记:第一行是否有 0 boolean firstRow = false; // 标记:第一列是否有 0 boolean firstCol = false; // 检查第一行是否有0 for (int j = 0; j < matrix[0].length; j++) { if (matrix[0][j] == 0) { firstRow = true; break; } } // 检查第一列是否有0 for (int i = 0; i < matrix.length; i++) { if (matrix[i][0] == 0) { firstCol = true; break; } } // 3. 遍历除第一行、第一列外的元素 // 如果 matrix[i][j] == 0,就标记到第一行和第一列 for (int i = 1; i < m; i++) { for (int j = 1; j < n; j++) { if (matrix[i][j] == 0) { matrix[i][0] = 0; // 标记第 i 行需要置 0 matrix[0][j] = 0; // 标记第 j 列需要置 0 } } } // 4. 根据第一列的标记,把对应行置为0 for (int i = 1; i < m; i++) { if (matrix[i][0] == 0) { for (int j = 1; j < n; j++) { matrix[i][j] = 0; } } } // 根据第一行的标记 把对应列置为0 for(int j = 1; j < n; j++){ if(matrix[0][j] == 0){ for(int i = 1;i<m;i++){ matrix[i][j] = 0; } } } //最后处理第一行 if(firstRow){ for(int j = 0;j<n;j++){ matrix[0][j] = 0; } } //处理第一列 if(firstCol){ for(int i = 0;i<m;i++){ matrix[i][0] = 0; } } } }
http://www.jsqmd.com/news/602535/

相关文章:

  • 告别手动上传:用VSCode的FTP-Sync插件自动化同步代码到宝塔服务器
  • 接地PIN的秘密:医疗连接器中的电磁安全基石
  • Python MCP服务器开发报错响应SOP(SLA≤3分钟:含自动诊断脚本+报错码速查表+GDB级协程堆栈捕获指令)
  • 使用JavaScript构建Nanbeige 4.1-3B模型的交互式前端应用
  • AI Agent协作模式以及主流开源框架对协作模式的支持
  • 跨平台资源下载工具 res-downloader:技术架构与实战指南
  • 不同发质护发精油排行榜:6款针对性护理的精油 - 博客万
  • 收藏!小白程序员必看:大模型Agent评估体系构建与核心风险解析
  • 语义分割骨干网络选型指南:MobileNet与Xception实战决策手册
  • 京东e卡回收攻略,了解快速变现方法! - 团团收购物卡回收
  • Z-Image-Turbo_UI界面功能详解:正向提示词怎么写?负向提示词为什么没用?
  • Gemma-3-12B-IT API实战:手把手教你打造内部知识库问答系统
  • Graphormer模型在C语言嵌入式系统中的轻量化部署与应用
  • biliup直播录制架构解析:构建高性能多平台流媒体处理系统
  • FastAPI流式AI接口被劫持?(2024最新MITRE ATTCK T1593.002攻击链实测复现与防御闭环)
  • 南京杰达家居提醒小心您的肺正在当“过滤器”,中央空调藏污纳垢需定期清洗保养 - 博客万
  • 跨越最后一公里:确保TVA从“成功上线”到“全面成功”的组织保障
  • 2026深圳SAT补习机构哪家靠谱?精品小班辅导 一对一培训机构推荐 - 品牌2026
  • 告别虚拟机!在Win11的WSL2里用Rust给STM32点灯,保姆级避坑指南(含CMSIS-DAP配置)
  • Windows 11变慢又卡顿?用Win11Debloat打造流畅系统体验
  • 【实战 01】任务定义:从经营维度构建 Text2SQL Agent 评测基准
  • 银泰百货卡回收方式详解:哪种方式更高效安全? - 团团收购物卡回收
  • 2026年AI资讯平台盘点与每日动态追踪指南
  • Gemma-3 Pixel Studio惊艳案例:博物馆藏品图→文物断代+工艺分析+同时期类似器物关联推荐
  • Hexo 博客图片管理革命:PicGo + GitHub 图床配置全攻略
  • 解锁3大维度:Helix Toolkit如何重构.NET开发者的3D开发体验
  • 如何快速获取B站视频资源?3分钟掌握bilibili-parse终极解析指南
  • 3个实用技巧轻松解决ComfyUI-Custom-Scripts新手难题
  • C语言项目代码审查利器:Phi-4-mini-reasoning深度分析指针与内存安全
  • 黑苹果网络配置完全指南:从问题诊断到性能优化