leetcode54. 螺旋矩阵(java)

螺旋矩阵

题目描述

难度 - 中等
原题链接 - leecode 54 螺旋矩阵
给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
示例1:
输入:matrix = \[1,2,3,4,5,6,7,8,9]

输出:1,2,3,6,9,8,7,4,5
示例2:
输入:matrix = \[1,2,3,4,5,6,7,8,9,10,11,12]

输出:1,2,3,4,8,12,11,10,9,5,6,7
提示:

m == matrix.length

n == matrixi.length

1 <= m, n <= 10

-100 <= matrixij <= 100

解题 收缩法

解题的核心思路是按照右、下、左、上的顺序遍历数组,并使用四个变量圈定未遍历元素的边界:
随着螺旋遍历,相应的边界会收缩,直到螺旋遍历完整个数组:
把上面过程翻译成代码:

java 复制代码
class Solution {
   List<Integer> spiralOrder(int[][] matrix) {
       int upper_bound = 0;
       int lower_bound = matrix.length - 1;
       int left_bound = 0;
       int right_bound = matrix[0].length - 1;
       List<Integer>ans = new LinkedList<>();
       while(ans.size() < matrix.length * matrix[0].length){
           //从左往右
           if(upper_bound <= lower_bound){
               for(int i = left_bound;i <= right_bound;i++){
                   ans.add(matrix[upper_bound][i]);
               }
               //上边界下移
               upper_bound++;
           }
           //从上到下
           if(left_bound <= right_bound){
               for(int i = upper_bound;i <= lower_bound;i++){
                   ans.add(matrix[i][right_bound]);
               }
               //右边界左移
               right_bound--;
           }

           //从右向左
           if(upper_bound <= lower_bound){
               for(int i = right_bound;i >= left_bound;i--){
                   ans.add(matrix[lower_bound][i]);
               }
               lower_bound--;
           }
           //从下向上
           if(left_bound <= right_bound){
               for(int i = lower_bound;i >= upper_bound;i--){
                   ans.add(matrix[i][left_bound]);
               }
               left_bound++;
           }
       }
       return ans;
   }

}

上期经典算法

leetcode48. 旋转图像

相关推荐
aqiu111111几秒前
python02
算法
折哥的程序人生 · 物流技术专研1 分钟前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
瓦特what?1 分钟前
位运算核心技巧与应用
java·jvm·算法
无限码力1 分钟前
阿里算法岗 0530笔试真题 - 荆棘林的最优砍断计划
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试真题·阿里巴巴笔试真题
人道领域3 分钟前
【LeetCode刷题日记】90.子集Ⅱ--- 归纳题解
java·开发语言·leetcode
会Tk矩阵群控的小木4 分钟前
小红书矩阵软件:基于Python+ADB的多设备批量管理自动化脚本实战
运维·python·adb·矩阵·自动化·新媒体运营·个人开发
随意起个昵称4 分钟前
线性dp-LIS题目5(导弹拦截,二分优化)
c++·算法·动态规划
winlife_4 分钟前
全程用 AI 做一款商业级手游 · EP10 道具系统:让三个按钮真正改变棋盘
windows·算法·unity·ai编程·游戏开发·mcp·玩法系统
IT策士5 分钟前
Redis 从入门到精通:数据结构Set 与 Sorted
数据结构·数据库·redis
计算机安禾8 分钟前
【数据库系统原理】第16篇:范式理论(下):多值依赖与第四范式——消除非平凡的非函数依赖
算法