当前位置: 首页 > news >正文

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

螺旋矩阵

  • https://leetcode.cn/problems/spiral-matrix/

描述

  • 给你一个 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 )减而治之递归实现

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, [])
};
  • 没办法一次性一圈圈的描述出来,但是可以把一圈的过程描述出来
  • 描述一圈经历了几件事: 顺时针
    • 二维矩阵第一行 (从做到右)
    • 二维矩阵最后一列 (从上到下)
    • 二维矩阵倒数第一行 (从右到左)
    • 二维矩阵第一列 (从下到上)
  • 整体算法
    • 先遍历第一圈,减而治之
    • 如果还有,则递归实现
http://www.lryc.cn/news/205275.html

相关文章:

  • LVS+keepalived高可用负载均衡集群
  • 解密Kubernetes:探索开源容器编排工具的内核
  • 苹果手机怎么设置壁纸?解锁设置壁纸的2种方法!
  • 解决LOGITECH 罗技驱动 MAC版出现的一些问题汇总!
  • PyQt5入门4——给目标检测算法构建一个简单的界面
  • Pandas数据分析系列9-数据透视与行列转换
  • 部分背包问题细节(贪心)
  • windows协议详解之-RPC/SMB/LDAP/LSA/SAM域控协议关系
  • uniapp中 background-image 设置背景图片不展示问题
  • Elasticsearch打分机制
  • 【pdf密码】为什么我的PDF文件不能复制文字?
  • vim程序编辑器
  • 新手如何学习挖漏洞?看这篇就够了【网络安全】
  • CentOS 7.8 kubeadm安装 k8s 1.26
  • 成都瀚网科技有限公司抖音小店:创新营销引领电商潮流
  • 警惕!又2本期刊被“On Hold”!
  • 一台服务器成了哆啦A梦的神奇口袋
  • java 关闭access文件资源后,无法删除文件
  • Typecho 添加 Emoji 表情报错「解决方案」
  • 【C#】委托与事件
  • 化工园区数字孪生可视化管控平台,赋予园区安全环保智慧发展
  • Laplacian算子详解及例程
  • 《数据结构与算法》学习指导手册
  • ubuntu安装配置mantis
  • node后端接收pdf接口
  • [RPC] Motan快速开始
  • 仿美团外卖微信小程序源码/美团外卖优惠券领劵小程序-自带流量主模式
  • 【Python】Windows跟随程序启动和关闭系统代理
  • 信钰证券:华为汽车概念股持续活跃 圣龙股份斩获12连板
  • LSM Tree 深度解析