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

矩阵-54. 螺旋矩阵

文章目录一、核心解题思路1. 核心思想边界收缩法模拟顺时针遍历2. 时间 / 空间复杂度二、完整 Java 代码符合大厂机考标准含控制台输入输出三、注意★★★边界判断的必要性力扣地址 中等54. 螺旋矩阵挺简单的一、核心解题思路1. 核心思想边界收缩法模拟顺时针遍历这道题的本质是模拟顺时针螺旋遍历矩阵的过程通过定义四个边界来控制遍历范围每遍历完一条边就收缩对应边界直到所有元素遍历完成。四个边界定义left当前遍历的左边界列索引right当前遍历的右边界列索引top当前遍历的上边界行索引bottom当前遍历的下边界行索引遍历顺序顺时针从左到右遍历上边界top行从left列到right列遍历完成后上边界top收缩上边界从上到下遍历右边界right列从top行到bottom行遍历完成后右边界right--收缩右边界从右到左遍历下边界bottom行从right列到left列遍历完成后下边界bottom--收缩下边界从下到上遍历左边界left列从bottom行到top行遍历完成后左边界left收缩左边界关键边界判断每完成一条边的遍历后必须判断边界是否越界比如top bottom或left right如果越界说明所有元素已经遍历完成直接终止循环避免重复遍历。2. 时间 / 空间复杂度时间复杂度O(m×n)矩阵中每个元素仅被访问一次空间复杂度O(1)除结果数组外仅使用常数额外空间classSolution{publicListIntegerspiralOrder(int[][]matrix){intleft0,rightmatrix[0].length-1,top0,bottommatrix.length-1;ListIntegerresnewArrayList();while(leftrighttopbottom){for(intileft;iright;i){res.add(matrix[top][i]);}top;if(topbottom)break;for(intitop;ibottom;i){res.add(matrix[i][right]);}right--;if(leftright)break;for(intiright;ileft;i--){res.add(matrix[bottom][i]);}bottom--;if(topbottom)break;for(intibottom;itop;i--){res.add(matrix[i][left]);}left;if(leftright)break;}returnres;}}二、完整 Java 代码符合大厂机考标准含控制台输入输出importjava.util.ArrayList;importjava.util.List;importjava.util.Scanner;publicclassMain{publicstaticListIntegerspiralOrder(int[][]matrix){// 定义四个边界intleft0;intrightmatrix[0].length-1;inttop0;intbottommatrix.length-1;ListIntegerresnewArrayList();while(leftrighttopbottom){// 1. 从左到右遍历上边界for(intileft;iright;i){res.add(matrix[top][i]);}top;// 上边界收缩if(topbottom)break;// 边界越界终止// 2. 从上到下遍历右边界for(intitop;ibottom;i){res.add(matrix[i][right]);}right--;// 右边界收缩if(leftright)break;// 边界越界终止// 3. 从右到左遍历下边界for(intiright;ileft;i--){res.add(matrix[bottom][i]);}bottom--;// 下边界收缩if(topbottom)break;// 边界越界终止// 4. 从下到上遍历左边界for(intibottom;itop;i--){res.add(matrix[i][left]);}left;// 左边界收缩if(leftright)break;// 边界越界终止}returnres;}publicstaticvoidmain(String[]args){ScannerscannernewScanner(System.in);intmscanner.nextInt();intnscanner.nextInt();int[][]matrixnewint[m][n];for(inti0;im;i){for(intj0;jn;j){matrix[i][j]scanner.nextInt();}}System.out.println(spiralOrder(matrix));}}三、注意★★★边界判断的必要性如果没有边界判断会出现重复遍历的问题比如只有一行的矩阵[[1,2,3,4]]第一步遍历完上边界后top1此时top bottombottom0如果不 break会继续执行后续遍历导致重复访问元素比如只有一列的矩阵[[1],[2],[3],[4]]第二步遍历完右边界后right-1此时left right如果不 break会继续执行后续遍历导致重复访问元素

相关文章:

矩阵-54. 螺旋矩阵

文章目录一、核心解题思路1. 核心思想:边界收缩法(模拟顺时针遍历)2. 时间 / 空间复杂度二、完整 Java 代码(符合大厂机考标准,含控制台输入输出)三、注意★★★边界判断的必要性力扣地址: 中等…...

ExplorerPatcher深度技术解析:Windows界面定制的终极系统级解决方案

ExplorerPatcher深度技术解析:Windows界面定制的终极系统级解决方案 【免费下载链接】ExplorerPatcher This project aims to enhance the working environment on Windows 项目地址: https://gitcode.com/GitHub_Trending/ex/ExplorerPatcher ExplorerPatch…...

别再手动下载了!用GEE批量导出MODIS MCD12Q1年度土地覆盖数据(附完整代码)

高效获取全球土地覆盖数据:基于GEE的MODIS MCD12Q1全自动处理方案 引言:为什么需要自动化处理土地覆盖数据? 在生态环境监测、气候变化研究和城市规划等领域,MODIS MCD12Q1年度土地覆盖数据是基础性关键数据集。传统手动下载方式不…...

AI驱动零代码浏览器自动化:三步轻松实现跨平台智能操作

AI驱动零代码浏览器自动化:三步轻松实现跨平台智能操作 【免费下载链接】midscene AI-powered, vision-driven UI automation for every platform. 项目地址: https://gitcode.com/GitHub_Trending/mid/midscene 厌倦了每天重复的浏览器操作?填写…...

电量计核心技术解析:从基础原理到智能应用

1. 电量计:电池的"智能管家" 想象一下你的手机电量显示从20%突然跳到5%,或者无人机在飞行中突然断电坠落——这些糟心体验的根源往往在于电量计量不准确。电量计就像电池的"智能管家",它不仅要回答"还剩多少电&quo…...

2026年人工智能AI原生型公司:面向规模化AI应用的企业架构设计研究报告

原文链接:https://tecdat.cn/?p45493原文出处:拓端抖音号拓端tecdat关于分析师在此对 YouMing Zhang 对本文所作的贡献表示诚挚感谢,他在东北大学完成了信息与计算科学专业的学士学位,专注人工智能领域。擅长机器学习、深度学习算…...

记一次企业src-oauth劫持漏洞挖掘

记一次企业src-oauth劫持漏洞挖掘 刚开始接触这个src的啥时候 发现有个主站的sso登录 也是常规替换url 发现不行 然后等操作进行绕过 发现并不可行 是严格的白名单校验 若不符合规则那么会如下图所示 当发现出现这样的情况后我就惯性的以为应该是不存在oauth劫持相关的漏洞 …...

【密码算法 之四】HMAC 实战:从原理到API安全调用

1. HMAC:API安全的隐形守护者 第一次接触HMAC是在五年前的一个支付系统项目里。当时我们的API频繁遭遇伪造请求攻击,直到引入HMAC签名机制后,安全问题才真正得到解决。这个看似简单的算法,如今已成为我设计API安全方案时的首选武器…...

代码审计 一次SQL注入漏洞挖掘

代码审计 一次SQL注入漏洞挖掘 免责声明:本作者所提供的文字和信息仅供学习和研究使用,不得用于任何非法用途。我们强烈谴责任何非法活动,并严格遵守法律法规。读者应该自觉遵守法律法规,不得利用本作者所提供的信息从事任何违法…...

5分钟彻底告别DLL错误:VisualCppRedist AIO一站式运行库解决方案

5分钟彻底告别DLL错误:VisualCppRedist AIO一站式运行库解决方案 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经在安装新软件时&#xff…...

【Matlab】移动机器人多传感器融合定位实现

【Matlab】移动机器人多传感器融合定位实现 一、引言 移动机器人的自主导航能力是其实现智能化作业的核心,而定位精度则直接决定导航系统的可靠性与实用性,广泛应用于仓储物流、服务机器人、工业巡检、自动驾驶等多个领域。移动机器人定位技术的核心的是实时获取机器人在全…...

告别传统PPT制作:探索PPTist如何重塑你的在线演示体验

告别传统PPT制作:探索PPTist如何重塑你的在线演示体验 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features of MS PowerPoint, allowing fo…...

计网实战:如何设计帧序号以最大化信道利用率

1. 从零理解帧序号设计的核心逻辑 第一次接触帧序号设计问题时,我和大多数初学者一样感到困惑:为什么几个简单的比特位能对网络性能产生如此大的影响?后来在实际项目中调试网络协议时才发现,这看似简单的数字背后藏着精妙的工程权…...

别再为Qt播放RTSP视频流报错发愁了,手把手教你搞定DirectShowPlayerService::doRender错误

Qt播放RTSP视频流报错全攻略:从DirectShowPlayerService错误到完美播放 在开发视频监控、远程会议或流媒体应用时,RTSP协议因其低延迟和实时性成为首选方案。然而当开发者满怀信心地使用Qt的QMediaPlayer组件时,却常常被一个冰冷的错误提示迎…...

HTML转Figma终极指南:三步实现网页到设计的智能转换

HTML转Figma终极指南:三步实现网页到设计的智能转换 【免费下载链接】figma-html Convert any website to editable Figma designs 项目地址: https://gitcode.com/gh_mirrors/fi/figma-html 你是否曾经想要将现有的网页设计快速转换为Figma文件进行编辑&…...

终极CrossOver优化工具:CXPatcher一键提升游戏兼容性

终极CrossOver优化工具:CXPatcher一键提升游戏兼容性 【免费下载链接】CXPatcher A patcher to upgrade Crossover dependencies and improve compatibility 项目地址: https://gitcode.com/gh_mirrors/cx/CXPatcher 你是否曾经在Mac上运行Windows游戏时遇到…...

终极CAJ转PDF解决方案:如何将知网文献转换为可搜索PDF

终极CAJ转PDF解决方案:如何将知网文献转换为可搜索PDF 【免费下载链接】caj2pdf Convert CAJ (China Academic Journals) files to PDF. 转换中国知网 CAJ 格式文献为 PDF。佛系转换,成功与否,皆是玄学。 项目地址: https://gitcode.com/gh…...

从SHP到Excel,再到CAD:一站式GIS数据格式转换实战指南

1. GIS数据格式转换的核心痛点 搞GIS数据处理的朋友都知道,最头疼的就是各种格式之间的转换问题。我做了十年国土空间规划,经手过上百个项目,发现90%的数据问题都出在格式转换环节。比如国土三调数据要用SHP格式入库,但外业测绘给…...

终极怀旧方案:如何一键恢复Bilibili经典界面与播放器

终极怀旧方案:如何一键恢复Bilibili经典界面与播放器 【免费下载链接】Bilibili-Old 恢复旧版Bilibili页面,为了那些念旧的人。 项目地址: https://gitcode.com/gh_mirrors/bi/Bilibili-Old 在B站不断迭代升级的今天,你是否曾怀念那个…...

【稀缺!内部白皮书级方法论】:生成式AI数据飞轮构建的4层验证体系(含可落地评估矩阵V2.3)

第一章:生成式AI应用数据飞轮构建 2026奇点智能技术大会(https://ml-summit.org) 生成式AI的持续进化高度依赖高质量、高密度、高反馈闭环的数据循环——即“数据飞轮”。该飞轮并非单向流水线,而是由用户交互、模型推理、人工反馈、数据增强与模型再训…...

PADS Layout高效操作指南:如何利用无模命令和快捷键提升PCB设计速度

PADS Layout高效操作指南:如何利用无模命令和快捷键提升PCB设计速度 在PCB设计领域,效率就是竞争力。当项目周期压缩到极限,当设计迭代频繁到令人窒息,那些能够快速完成高质量布局的设计师总能脱颖而出。PADS Layout作为业界广泛使…...

为什么92%的多模态服务在流量突增时静默降级?——用混沌工程定位ViT-LLM联合编码器的隐式瓶颈

第一章:为什么92%的多模态服务在流量突增时静默降级?——用混沌工程定位ViT-LLM联合编码器的隐式瓶颈 2026奇点智能技术大会(https://ml-summit.org) 多模态服务在真实生产环境中遭遇流量洪峰时,常出现响应延迟陡增、token生成跳变、图像特征…...

NAS玩家必看!在群晖Docker部署Navidrome的完整避坑指南

群晖NAS玩家专属:Docker部署Navidrome音乐服务器的深度实践指南 你是否厌倦了音乐平台的版权限制和音质压缩?作为NAS设备用户,你完全可以在群晖DSM系统中搭建属于自己的高保真音乐服务器。本文将带你深入探索Navidrome这一开源音乐服务器的部…...

终极指南:使用netDxf在.NET中轻松读写DXF文件

终极指南:使用netDxf在.NET中轻松读写DXF文件 【免费下载链接】netDxf .net dxf Reader-Writer 项目地址: https://gitcode.com/gh_mirrors/ne/netDxf 你是否正在寻找一个强大的.NET库来处理AutoCAD DXF文件?netDxf正是你需要的解决方案&#xff…...

OpenWrt防火墙配置避坑指南:从零开始手把手教你设置NAT和端口转发

OpenWrt防火墙配置实战:NAT与端口转发的深度解析与避坑指南 第一次接触OpenWrt防火墙配置时,我被那些看似复杂的规则和术语弄得晕头转向。直到家里的监控摄像头无法远程访问,才意识到正确配置NAT和端口转发的重要性。本文将带你从实际应用场景…...

Dockerfile实战:从零构建轻量级JDK1.8运行环境

1. 为什么需要轻量级JDK1.8运行环境? 在Java开发中,JDK1.8因其稳定性和丰富的特性集,至今仍是许多企业项目的首选版本。但传统的JDK安装方式存在几个痛点:首先是环境配置复杂,需要手动设置JAVA_HOME等环境变量&#x…...

Electron应用自动更新实战:从配置到发布的完整指南

1. 为什么Electron应用需要自动更新? 每次手动打包发布新版本对开发者来说简直是噩梦。想象一下:你刚修复了一个紧急bug,需要用户立即更新,难道要让每个用户都重新下载安装包吗?自动更新功能就像给应用装上了翅膀&…...

从‘火柴人’到精致模型:手把手教你用GraphicData打造RimWorld Mod的视觉差异化

从‘火柴人’到精致模型:用GraphicData打造RimWorld Mod的视觉差异化 当你第一次打开RimWorld的Mod开发工具时,可能会被那些简陋的"火柴人"式贴图吓到——它们僵硬、单调,与游戏原版精致的视觉效果格格不入。但别担心,这…...

FFmpeg在Qt中的高级应用:如何用C++实现低延迟监控画面展示(含线程优化技巧)

FFmpeg与Qt融合实战:构建工业级低延迟监控系统的核心技术解析 在实时视频处理领域,延迟控制是衡量系统性能的关键指标。当我们将FFmpeg这一强大的多媒体处理框架与Qt的跨平台GUI能力相结合时,如何实现毫秒级的视频延迟成为开发者面临的核心挑…...

答辩 PPT「躺赢」指南:Paperxie AI 生成器,30 分钟搞定毕业答辩

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AI PPThttps://www.paperxie.cn/ppt/createhttps://www.paperxie.cn/ppt/create 一、毕业季的 PPT 焦虑,终于有解药了 谁懂啊家人们!毕业论文写完不是结束,答辩 PPT 才是…...