news 2026/4/16 12:59:35

重走力扣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/16 12:45:37

少走弯路!新人使用VibeThinker-1.5B必看建议

少走弯路&#xff01;新人使用VibeThinker-1.5B必看建议 刚点开VibeThinker-1.5B-WEBUI网页界面时&#xff0c;你可能会愣一下&#xff1a;没有炫酷的对话框&#xff0c;没有预设按钮&#xff0c;只有一个空荡荡的输入框&#xff0c;外加一行小字提示——“系统提示词”。别急…

作者头像 李华
网站建设 2026/4/15 7:51:47

如何进行Cursor试用期重置:实现免费无限试用的完整指南

如何进行Cursor试用期重置&#xff1a;实现免费无限试用的完整指南 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on this machine. Please upgrade to pro. We…

作者头像 李华
网站建设 2026/4/16 10:43:33

2026动态捕捉推荐:8款专业产品全方位测评

✨ 动态捕捉技术正在重塑我们理解人类运动的方式。从运动科学到医疗康复&#xff0c;从影视特效到游戏开发&#xff0c;这项技术已成为连接物理世界与数字世界的桥梁。今天&#xff0c;我们为您带来2023年最值得推荐的8款动态捕捉系统&#xff0c;助您找到最适合的专业解决方案…

作者头像 李华
网站建设 2026/4/16 9:18:59

3步突破黑苹果技术壁垒:OpCore Simplify让EFI配置效率提升80%

3步突破黑苹果技术壁垒&#xff1a;OpCore Simplify让EFI配置效率提升80% 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 深夜两点&#xff0c;技术员…

作者头像 李华
网站建设 2026/4/16 9:18:14

Z-Image-Edit艺术风格迁移:油画效果生成详细步骤

Z-Image-Edit艺术风格迁移&#xff1a;油画效果生成详细步骤 1. 为什么选Z-Image-Edit做油画风格迁移 很多人问&#xff1a;市面上图像编辑工具这么多&#xff0c;为什么专门用Z-Image-Edit来实现油画效果&#xff1f;答案很实在——它不是“能做”&#xff0c;而是“做得准、…

作者头像 李华