数据结构与算法之矩阵: Leetcode 134. 螺旋矩阵 (Typescript版)

螺旋矩阵

描述

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

示例 1

复制代码
输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,3,6,9,8,7,4,5]

示例 2

复制代码
输入:matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]
输出:[1,2,3,4,8,12,11,10,9,5,6,7]

提示

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 10
  • -100 <= matrix[i][j] <= 100

算法实现

1 )减而治之递归实现

ts 复制代码
function spiralOrder(matrix: number[][]): number[] {
    // 处理每一圈的数据遍历过程
  const map = (arr: number[][], r: number[] = []) => {
    // 第一圈的遍历:遍历的时候不会按照 if else if 的顺序遍历,而是会按照一行一行的遍历,所以最终顺序不用担心
    for (let i = 0, len = arr.length; i < len; i++) {
      if (i === 0) {
        r = r.concat(arr[i])
      } else if (i === len - 1) {
        r = r.concat(arr[i].reverse())
      } else {
        // 增加边界检查
        if (arr[i].length) {
          r.push(arr[i].pop())
        }
      }
    }
    arr.shift() // 减而治之:移除第一行
    arr.pop() // 减而治之:移除最后一行
    // 第一圈最后的遍历: 倒序,从下到上
    for (let i = arr.length - 1; i >= 0; i--) {
      // 边界检查
      if (arr[i].length) {
        r.push(arr[i].shift())
      }
    }
    // 边界判断,是否还有,有则进行递归
    if (arr.length) {
      return map(arr, r)
    }
    // 没有直接返回
    return r;
  }
  return map(matrix, [])
};
  • 没办法一次性一圈圈的描述出来,但是可以把一圈的过程描述出来
  • 描述一圈经历了几件事: 顺时针
    • 二维矩阵第一行 (从做到右)
    • 二维矩阵最后一列 (从上到下)
    • 二维矩阵倒数第一行 (从右到左)
    • 二维矩阵第一列 (从下到上)
  • 整体算法
    • 先遍历第一圈,减而治之
    • 如果还有,则递归实现
相关推荐
m0_748708051 天前
C++中的观察者模式实战
开发语言·c++·算法
然哥依旧1 天前
【轴承故障诊断】基于融合鱼鹰和柯西变异的麻雀优化算法OCSSA-VMD-CNN-BILSTM轴承诊断研究【西储大学数据】(Matlab代码实现)
算法·支持向量机·matlab·cnn
qq_537562671 天前
跨语言调用C++接口
开发语言·c++·算法
Tingjct1 天前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
C雨后彩虹1 天前
计算疫情扩散时间
java·数据结构·算法·华为·面试
yyy(十一月限定版)1 天前
寒假集训4——二分排序
算法
星火开发设计1 天前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
醉颜凉1 天前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐1 天前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗1 天前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl