news 2026/6/9 22:45: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/6/9 18:50:42

OpenArk安全分析与系统防护使用指南

OpenArk安全分析与系统防护使用指南 【免费下载链接】OpenArk The Next Generation of Anti-Rookit(ARK) tool for Windows. 项目地址: https://gitcode.com/GitHub_Trending/op/OpenArk OpenArk作为新一代免费开源的Windows安全工具&#xff0c;集成了进程监控、内核分…

作者头像 李华
网站建设 2026/6/9 19:43:10

Windows 7系统Python 3.8-3.14版本安装技术指南

Windows 7系统Python 3.8-3.14版本安装技术指南 【免费下载链接】PythonWin7 Python 3.9 installers that support Windows 7 SP1 and Windows Server 2008 R2 项目地址: https://gitcode.com/gh_mirrors/py/PythonWin7 &#x1f50d; 问题诊断&#xff1a;Windows 7 Py…

作者头像 李华
网站建设 2026/6/9 22:13:44

3个技巧优化Cursor软件试用期管理体验

3个技巧优化Cursor软件试用期管理体验 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on this machine. Please upgrade to pro. We have this limit in place t…

作者头像 李华
网站建设 2026/6/7 2:29:24

告别繁琐配置:智能黑苹果EFI生成工具全解析

告别繁琐配置&#xff1a;智能黑苹果EFI生成工具全解析 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 你是否曾遇到过这些困扰&#xff1a;下载了十几…

作者头像 李华
网站建设 2026/6/7 2:20:41

显卡画质增强神器:OptiScaler让老旧显卡逆袭超高清体验

显卡画质增强神器&#xff1a;OptiScaler让老旧显卡逆袭超高清体验 【免费下载链接】OptiScaler DLSS replacement for AMD/Intel/Nvidia cards with multiple upscalers (XeSS/FSR2/DLSS) 项目地址: https://gitcode.com/GitHub_Trending/op/OptiScaler 痛点解析&#…

作者头像 李华
网站建设 2026/6/7 7:43:55

Qwen2.5-1.5B部署教程:3步完成Streamlit聊天界面+自动显存优化

Qwen2.5-1.5B部署教程&#xff1a;3步完成Streamlit聊天界面自动显存优化 1. 为什么你需要一个本地运行的1.5B对话助手 你有没有遇到过这些情况&#xff1a;想快速查个技术概念&#xff0c;却要等网页加载、登录账号、还要担心提问被记录&#xff1b;写一段产品文案&#xff…

作者头像 李华