【 每天学习一点算法 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)

相关推荐
何陋轩18 分钟前
【重磅】悟空来了:国产AI编程助手深度测评,能否吊打Copilot?
人工智能·算法·面试
星幻元宇VR20 分钟前
VR单人地震体验平台,学习科学避险
科技·学习·安全·vr·虚拟现实
坚持就完事了20 分钟前
Hadoop实战初步学习
hadoop·学习
for_ever_love__38 分钟前
UI学习:多界面传值的正向传值(属性传值)和反向传值(代理传值)
学习·ui·ios·objective-c
zhangrelay1 小时前
蓝桥云课五分钟-通关自动控制-octave
笔记·学习
逸风尊者1 小时前
XGBoost模型工程使用
java·后端·算法
LUVK_1 小时前
第七章查找
数据结构·c++·考研·算法·408
jiayong231 小时前
第 36 课:任务详情抽屉快捷改状态
开发语言·前端·javascript·vue.js·学习
khalil10201 小时前
代码随想录算法训练营Day-31贪心算法 | 56. 合并区间、738. 单调递增的数字、968. 监控二叉树
数据结构·c++·算法·leetcode·贪心算法·二叉树·递归
笔夏1 小时前
【安卓学习之混淆】记录一些混淆导致闪退
android·学习