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

相关推荐
一只齐刘海的猫9 分钟前
【Leetcode】移动零
算法·leetcode·职场和发展
MartinYeung532 分钟前
[论文学习]基于梯度迭代上下文优化的 LLM 隐私越狱攻击框架
学习·区块链
落羽的落羽1 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler011 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
MartinYeung51 小时前
[论文学习]大型语言模型中 PII 洩漏的系统性调查
学习
qq7422349842 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
.千余2 小时前
【C++】C++手写Vector容器:从底层源码模拟实现
开发语言·c++·经验分享·笔记·学习
huohaiyu2 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.3 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶3 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络