【 每天学习一点算法 2026/04/21】螺旋矩阵

每天学习一点算法 2026/04/21

题目:螺旋矩阵

给你一个 mn 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

我们简单分析一下返回的循序:

  1. 第 1 行,1 ~ n
  2. 第 n 列,2 ~ m
  3. 第 m 行,n - 1 ~ 1
  4. 第 1 列,m - 1 ~ 2
  5. 第 2 行,2 ~ n - 1
  6. 第 n - 1 列,3 ~ m - 1
  7. 第 m - 1 行, n - 2 ~ 2
  8. 第 2 列,m - 2 ~ 3

其实已经可以看出规律是,每循环一圈,下一次就将每一个方向的范围两边都减少 1。

然后就是要考虑如何控制边界,我们只需要等到四个方向的某一个的范围左边界大于右边界时,表示已经遍历完成。

注意上面的范围时 1 ~ n 和 1 ~ m,数组下标是 0 开始的,范围要减一。

typescript 复制代码
function spiralOrder(matrix: number[][]): number[] {
  const res = [] // 结果数组
  const m = matrix.length
  const n = matrix[0].length
  let level = 0 // 层级
  // 循环遍历直到范围无效
  while (true) {
    // 上方
    if (level <= n - level - 1) {
      for (let i = level; i < n - level; i++) {
        res.push(matrix[level][i])
      }
    } else {
      return res
    }
	// 右方
    if (level + 1 <= m - level - 1) {
      for (let i = level + 1; i < m - level; i++) {
        res.push(matrix[i][n - level - 1])
      }
    } else {
      return res
    }
	// 下方
    if (n - level - 2 >= level) {
      for (let i = n - level - 2; i >= level; i--) {
        res.push(matrix[m - level - 1][i])
      }
    } else {
      return res
    }
	// 左方
    if (m - level - 2 >= level + 1) {
      for (let i = m - level - 2; i >= level + 1; i--) {
        res.push(matrix[i][level])
      }
    } else {
      return res
    }

    level++
  }
};

如果觉得上面这种遍历边界判断太绕了也可以这样:

  1. 第 1 行,1 ~ n
  2. 第 n 列,2 ~ m - 1
  3. 第 m 行,n ~ 1
  4. 第 1 列,m - 1 ~ 2
  5. 第 2 行,2 ~ n - 1
  6. 第 n - 1 列,3 ~ m - 2
  7. 第 m - 1 行, n - 1 ~ 2
  8. 第 2 列,m - 2 ~ 3

也就是上下都取满,左右取夹在上下中间的部分,但是要先取上下,再取左右,代码这里就不写了。

题目来源:力扣(LeetCode)

相关推荐
_清歌1 小时前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局1 小时前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象1 小时前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局1 小时前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局1 小时前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局1 小时前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法
To_OC12 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵16 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC18 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode