LeetCode Hot100(15/100)——54. 螺旋矩阵

文章目录

题目链接:LeetCode CN - 螺旋矩阵


一、题目描述

给定一个 m x n 的二维矩阵 matrix,请按照 顺时针螺旋顺序 返回该矩阵中的所有元素。

示例输入:

复制代码
matrix = [
  [1, 2, 3],
  [4, 5, 6],
  [7, 8, 9]
]

示例输出:

复制代码
[1, 2, 3, 6, 9, 8, 7, 4, 5]

二、思路讲解

我们需要按照螺旋的顺序遍历矩阵------即 从左到右、从上到下、从右到左、从下到上 依次循环,直到所有元素都被访问完。


三、可视化流程解析

可以将矩阵的边界设定为四个变量:

  • top:当前剩余部分的上边界;
  • bottom:当前剩余部分的下边界;
  • left:当前剩余部分的左边界;
  • right:当前剩余部分的右边界。

每一次循环遍历,按照以下顺序访问元素:

  1. 从左到右;
  2. 从上到下;
  3. 从右到左;
  4. 从下到上;
  5. 缩小边界范围。

Mermaid 流程图(螺旋遍历过程)





开始
是否已遍历完所有元素?
从左到右遍历 top 行
从上到下遍历 right 列
是否剩余多行多列?
从右到左遍历 bottom 行
从下到上遍历 left 列
缩小边界 top++, bottom--, left++, right--
结束


Mermaid 思维导图(整体思路)

螺旋矩阵
思路
定义四个边界
按顺序遍历
每次循环收缩边界
实现
条件判断防止越界
使用 while 循环遍历
时间复杂度
O(m*n)
空间复杂度
O(1)


四、逐步实例演示

以如下矩阵为例:

复制代码
[
 [1, 2, 3],
 [4, 5, 6],
 [7, 8, 9]
]
步骤 遍历方向 遍历元素 结果数组
1 从左到右 1, 2, 3 [1, 2, 3]
2 从上到下 6, 9 [1, 2, 3, 6, 9]
3 从右到左 8, 7 [1, 2, 3, 6, 9, 8, 7]
4 从下到上 4 [1, 2, 3, 6, 9, 8, 7, 4]
5 再次从左到右 5 [1, 2, 3, 6, 9, 8, 7, 4, 5]

完成遍历。


五、Java 实现代码

java 复制代码
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
        List<Integer> res = new ArrayList<>();
        if (matrix == null || matrix.length == 0) return res;

        int top = 0, bottom = matrix.length - 1;
        int left = 0, right = matrix[0].length - 1;

        while (top <= bottom && left <= right) {
            // 从左到右
            for (int i = left; i <= right; i++) {
                res.add(matrix[top][i]);
            }
            top++;

            // 从上到下
            for (int i = top; i <= bottom; i++) {
                res.add(matrix[i][right]);
            }
            right--;

            // 判断剩余是否还有行或列
            if (top <= bottom) {
                // 从右到左
                for (int i = right; i >= left; i--) {
                    res.add(matrix[bottom][i]);
                }
                bottom--;
            }

            if (left <= right) {
                // 从下到上
                for (int i = bottom; i >= top; i--) {
                    res.add(matrix[i][left]);
                }
                left++;
            }
        }

        return res;
    }
}

六、复杂度分析

项目 说明 复杂度
时间复杂度 每个元素被访问一次 O(m × n)
空间复杂度 除输出外无额外存储 O(1)

七、总结

  • 关键思想:利用四个边界控制螺旋遍历;
  • 循环条件top <= bottom && left <= right
  • 注意点
    1. 每个方向遍历后需及时更新边界;
    2. 防止重复访问或越界。

这种思路是矩阵模拟类题型典型的"层层收缩"模型,掌握后可以轻松应用于类似题目(如「螺旋矩阵 II」生成题)。

相关推荐
超级码力6665 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑5 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind6 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师6 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F9 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业9 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn9 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室10 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星10 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿11 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算