news 2026/5/1 12:10:58

重走力扣hot的矩阵

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
重走力扣hot的矩阵

目录

矩阵置零

螺旋矩阵


矩阵置零

73. 矩阵置零 - 力扣(LeetCode)

法一:

引入两个HashSet容器,分别记录元素为0的横坐标与纵坐标

空:O(M+N)

代码

class Solution_2026_1_26_1 { int m; int n; public void setZeroes(int[][] matrix) { Set<Integer> row_zero=new HashSet(); Set<Integer> col_zero=new HashSet(); m=matrix.length; n=matrix[0].length; for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ if(matrix[i][j]==0){ row_zero.add(i); col_zero.add(j); } } } for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ //Set无get方法 if(row_zero.contains(i)||col_zero.contains(j)){ matrix[i][j]=0; } } } } }

优化:空间复杂度优化为O(1)

重点:区分第一行和第一列的0是本身就是0还是被修改为0的

class Solution { public void setZeroes(int[][] matrix) { //进行优化 空间复杂度降低为O(1) boolean hasRowZero=false; boolean hasColZero=false; int m=matrix.length; int n=matrix[0].length; //检查第一行是否有为0的 for(int i=0;i<n;i++){ //检查第一行是否为空 //但本质上第一行处理的是列 if(matrix[0][i]==0){ hasRowZero=true; break; } } for(int i=0;i<m;i++){ //检查第一列是否为空 //但本质上第一列处理的是行 if(matrix[i][0]==0){ hasColZero=true; break; } } //遍历二维数组 进行标记 for(int i=1;i<m;i++){ for(int j=1;j<n;j++){ if(matrix[i][j]==0){ matrix[0][j]=0; matrix[i][0]=0; } } } for(int i=1;i<m;i++){ for(int j=1;j<n;j++){ if(matrix[0][j]==0||matrix[i][0]==0){ matrix[i][j]=0; } } } //单独处理第一行为0的情况 if(hasRowZero){ for(int i=0;i<n;i++){ matrix[0][i]=0; } } if(hasColZero){ for(int i=0;i<m;i++){ matrix[i][0]=0; } } } }

螺旋矩阵

54. 螺旋矩阵 - 力扣(LeetCode)

个人认为关键点就是理清除过程,先从左往右处理上边界,然后从上往下处理右边界,然后从右往左处理下边界,最后在从下往上处理左边界即可,理清楚过程即可

class Solution { public List<Integer> spiralOrder(int[][] matrix) { int m=matrix.length; int n=matrix[0].length; List<Integer> ret=new ArrayList<>(); int left=0; int right=n-1; int top=0; int bottom=m-1; while(left<=right&&top<=bottom){ for(int i=left;i<=right;i++){ ret.add(matrix[top][i]); //从左往右处理 } top++; //从上往下 for(int i=top;i<=bottom;i++){ ret.add(matrix[i][right]); //从下往上处理 } right--; //从后往前 if(top<=bottom){ for(int i=right;i>=left;i--){ //从后往前 ret.add(matrix[bottom][i]); } //从下往上 bottom--; } if(left<=right){ for(int i=bottom;i>=top;i--){ ret.add(matrix[i][left]); } //从前往后 left++; } } return ret; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/27 9:13:20

YOLOv9官方镜像常见问题解答,新手必读

YOLOv9官方镜像常见问题解答&#xff0c;新手必读 你刚拉取了 YOLOv9 官方版训练与推理镜像&#xff0c;双击启动&#xff0c;终端亮起——但下一秒卡在 conda activate yolov9&#xff1f;运行 detect_dual.py 报错 ModuleNotFoundError: No module named torch&#xff1f;训…

作者头像 李华
网站建设 2026/4/30 1:30:04

multisim14.3安装后配置基础元件库的新手指南

以下是对您原始博文内容的 深度润色与重构版本 。我以一位深耕电路仿真十余年的工程师兼高校实践课讲师身份&#xff0c;用更自然、更具教学感和实战穿透力的语言重写全文—— 去除AI腔调、打破模板化结构、强化问题驱动逻辑、融入真实踩坑经验&#xff0c;并大幅增强可操作…

作者头像 李华
网站建设 2026/4/27 7:50:44

OpenArk:Windows系统安全的守护者

OpenArk&#xff1a;Windows系统安全的守护者 【免费下载链接】OpenArk The Next Generation of Anti-Rookit(ARK) tool for Windows. 项目地址: https://gitcode.com/GitHub_Trending/op/OpenArk 在数字化时代&#xff0c;系统安全面临着日益严峻的挑战。恶意软件的潜伏…

作者头像 李华
网站建设 2026/5/1 10:49:40

指定输出目录?-d参数轻松搞定新路径

指定输出目录&#xff1f;-d参数轻松搞定新路径 你是否遇到过这样的情况&#xff1a;运行完人像抠图脚本&#xff0c;结果图片一股脑全堆在当前文件夹里&#xff0c;和代码、日志、测试图混在一起&#xff0c;找都找不到&#xff1f;或者想把不同批次的抠图结果分门别类存到不…

作者头像 李华
网站建设 2026/4/29 16:46:27

万物识别助力智慧农业:作物生长阶段识别系统搭建教程

万物识别助力智慧农业&#xff1a;作物生长阶段识别系统搭建教程 在田间地头&#xff0c;农民最关心的不是算法有多复杂&#xff0c;而是“这株玉米是不是快抽穗了&#xff1f;”“这片水稻有没有感染病害&#xff1f;”——真实农业场景里&#xff0c;问题从来都是具体的、带…

作者头像 李华
网站建设 2026/4/22 1:22:12

AtlasOS完全指南:让老旧电脑效率倍增的系统优化方案

AtlasOS完全指南&#xff1a;让老旧电脑效率倍增的系统优化方案 【免费下载链接】Atlas &#x1f680; An open and lightweight modification to Windows, designed to optimize performance, privacy and security. 项目地址: https://gitcode.com/GitHub_Trending/atlas1/…

作者头像 李华