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

相关推荐
Kiling_07046 分钟前
Java集合进阶:Set与Collections详解
算法·哈希算法
智者知已应修善业27 分钟前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
·醉挽清风·41 分钟前
学习笔记—MySQL—库表操作
笔记·学习·mysql
洛水水1 小时前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI1 小时前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞2 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
白小沫2 小时前
TortoiseSVN是什么?
学习
weixin_451431562 小时前
【学习笔记】微博视频页面ajax请求与响应数据分析
笔记·学习·音视频
清辞8533 小时前
尾盘选股法程序开发学习初期
学习
Century_Dragon4 小时前
让实训“活”起来——信息化综合实训考核平台助力汽车专业教学
学习