LeetCode hot100 -54.螺旋矩阵

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

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

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

转向是如何进行的呢?

DIRS 10 是什么?

  • 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/

相关推荐
浮芷.16 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶16 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion16 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡16 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf201916 小时前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室17 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习
8Qi817 小时前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者17 小时前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
2601_9611940217 小时前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene
AI科技星17 小时前
基于奇合数边界的离散解析数论与双螺旋宇宙本体大统一体系论文全部数学公式汇总表
人工智能·算法·机器学习·架构·学习方法