LeetCode hot100 -54.螺旋矩阵

这道题我们采用标记的方式,走的方式从左上角开始,沿着右下左上的方位进行螺旋。

首先我们定义这四个方位的常二维数组,一定不要定义错,否则会有报错。

然后我们一共会走m*n步,得到最终结果。当到达某个方位的边界时,我们需要转向。走过某个点之后我们把它标记为正无穷,也就是int类型的最大值,或者是null。我们定义x,y先尝试沿着当前方向走一步,判断是否出界,没出界,就迈出这一步。

转向是如何进行的呢?

DIRS [1][0] 是什么?

  • DIRS[1] = 第二个数组:{1, 0}
  • DIRS[1][0] = 这个数组里第 0 号元素1

DIRS[di] :当前方向的移动增量

  • di=0{0,1} → 行不变,列 + 1 → 向右
  • di=1{1,0} → 行 + 1,列不变 → 向下
  • di=2{0,-1} → 行不变,列 - 1 → 向左
  • di=3{-1,0} → 行 - 1,列不变 → 向上

最后代码如下:

  • 时间复杂度:O(mn),其中 m 和 n 分别为 matrix 的行数和列数。
  • 空间复杂度:O(1)。返回值不计入。
java 复制代码
class Solution {
    private static final int[][] DIR ={{0,1},{1,0},{0,-1},{-1,0}};
    public List<Integer> spiralOrder(int[][] matrix) {
        int m = matrix.length;
        int n = matrix[0].length;
        List<Integer> ans = new ArrayList<>(m * n);
        int i = 0;
        int j = 0;
        int di = 0;
        for(int k = 0; k < m * n;k++){
            ans.add(matrix[i][j]);
            matrix[i][j] = Integer.MAX_VALUE;
            int x = i + DIR[di][0];
            int y = j + DIR[di][1];
            if(x < 0 || x >= m || y < 0 || y >=n || matrix[x][y] == Integer.MAX_VALUE){
                di = (di+1) % 4;
            }
            i += DIR[di][0];
            j += DIR[di][1];
        }
        return ans;
    }
}

其他解法可参考:

作者:灵茶山艾府

链接:https://leetcode.cn/problems/spiral-matrix/solutions/2966229/liang-chong-fang-fa-jian-ji-gao-xiao-pyt-4wzk/

相关推荐
weixin_468466852 小时前
排列组合算法之隔板问题与错排公式
c++·算法·数学建模·排列组合·竞赛·错排·隔板
wsoz2 小时前
Leetcode链表-day9
c++·算法·leetcode·链表
Lumos_7772 小时前
Linux -- 系统调用
linux·运维·算法
一个行走的民2 小时前
深度剖析 Ceph PG 分裂机制:原理、底层、实操、影响、线上避坑(最全完整版)
ceph·算法
WolfGang0073213 小时前
代码随想录算法训练营 Day46 | 图论 part04
算法·图论
拾-光3 小时前
LTX-Video 2.3 实战:用图片生成视频,消费级显卡也能跑的开源 I2V 模型(GPT Image 2)
java·人工智能·python·深度学习·算法·机器学习·音视频
小O的算法实验室3 小时前
2026年ESWA,考虑曲率约束路径优化的 Dubins-RRT* 运动规划算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
jllllyuz3 小时前
灰狼算法优化的LSSVR程序
算法
杨校3 小时前
杨校老师课堂之栈结构的专项训练
算法