news 2026/6/7 4:21:45

重走力扣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/18 6:32:20

中小企业如何降本做语音合成?CosyVoice-300M Lite实战案例

中小企业如何降本做语音合成&#xff1f;CosyVoice-300M Lite实战案例 1. 为什么中小企业需要“能用、好用、不烧钱”的语音合成&#xff1f; 你有没有遇到过这些场景&#xff1f; 电商团队要为上百款商品录制口播短视频&#xff0c;外包配音一小时报价800元&#xff0c;一周…

作者头像 李华
网站建设 2026/5/29 5:15:12

开发者必看:VibeThinker-1.5B代码生成实战测评与调优技巧

开发者必看&#xff1a;VibeThinker-1.5B代码生成实战测评与调优技巧 1. 为什么小模型突然值得你花10分钟认真看看 你有没有试过在本地跑一个能真正写代码的模型&#xff0c;却只用不到4GB显存&#xff1f;不是“勉强能动”&#xff0c;而是面对Leetcode中等题能给出完整、可…

作者头像 李华
网站建设 2026/6/5 22:06:33

黑苹果配置不再难?3个智能工具让你1小时上手

黑苹果配置不再难&#xff1f;3个智能工具让你1小时上手 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为OpenCore配置头痛不已&#xff1f;传统…

作者头像 李华
网站建设 2026/6/6 23:26:53

智能金融预测工具Kronos:用AI重塑交易决策流程

智能金融预测工具Kronos&#xff1a;用AI重塑交易决策流程 【免费下载链接】Kronos Kronos: A Foundation Model for the Language of Financial Markets 项目地址: https://gitcode.com/GitHub_Trending/kronos14/Kronos 在瞬息万变的金融市场中&#xff0c;每位投资者…

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

零基础3分钟部署Phi-3-mini-4k-instruct:Ollama一键安装教程

零基础3分钟部署Phi-3-mini-4k-instruct&#xff1a;Ollama一键安装教程 你是不是也试过下载模型、配置环境、编译依赖&#xff0c;折腾半天却卡在“ImportError: No module named llama_cpp”&#xff1f;是不是看到“3.8B参数”就下意识觉得需要RTX 4090和32GB内存&#xff…

作者头像 李华
网站建设 2026/5/20 16:40:42

Qwen3-1.7B适合哪些场景?开发者使用建议汇总

Qwen3-1.7B适合哪些场景&#xff1f;开发者使用建议汇总 导语&#xff1a;17亿参数的Qwen3-1.7B不是“缩水版”&#xff0c;而是经过重新设计的轻量级智能体——它不靠堆参数取胜&#xff0c;而靠双模式切换、长上下文理解与工具友好架构&#xff0c;在真实开发场景中跑出高性…

作者头像 李华