千家信息网

JavaScript旋转二维数组的方法

发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,这篇文章主要讲解了"JavaScript旋转二维数组的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JavaScript旋转二维数组的方法"吧!一
千家信息网最后更新 2025年11月09日JavaScript旋转二维数组的方法

这篇文章主要讲解了"JavaScript旋转二维数组的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JavaScript旋转二维数组的方法"吧!

一、题目描述

给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。

你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。

示例 1:

输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]

输出:[[7,4,1],[8,5,2],[9,6,3]]

示例 2:

输入:matrix = [[5,1,9,11],[2,4,8,10],[13,3,6,7],[15,14,12,16]]

输出:[[15,13,2,5],[14,3,4,1],[12,6,8,9],[16,7,10,11]]

二、思路与实现

从示例图中就可以知道:

数组顺时针旋转 90 度之后,其实就是第1列变成第1行,第2列变成第2行,第3列变成第3行......

实现一:

/*** @param {number[][]} matrix* @return {void} Do not return anything, modify matrix in-place instead.*/var rotate = function (matrix) {let n = matrix.length;let res = new Array(n).fill(0).map(() => new Array(n).fill(0));for (let i = 0; i < n; i++)for (let j = n - 1; j >= 0; j--) res[i][n - j - 1] = matrix[j][i];return res;};

时间复杂度:O(N^2),其中N为matrix的边长
空间复杂度:O(N^2)。我们需要使用一个和 matrix 大小相同的辅助数组。

还有另外一种思路:

  • 按照左上到右下的对角线进行镜像对称

  • 对矩阵的每一行进行反转

比如这样:

/*** @param {number[][]} matrix* @return {void} Do not return anything, modify matrix in-place instead.*/var rotate = function (matrix) {let n = matrix.length;// 先沿对角线镜像对称二维矩阵for (let i = 0; i < n; i++) {for (let j = i; j < n; j++) {[matrix[i][j], matrix[j][i]] = [matrix[j][i], matrix[i][j]];}}const reverseRow = (arr) => {let i = 0,j = arr.length - 1;while (i <= j) {[arr[i], arr[j]] = [arr[j], arr[i]];i++;j--;}};// 然后反转二维矩阵的每一行for (let row of matrix) {reverseRow(row);}return matrix;};
  • 时间复杂度跟解法1一样,但是却不需要额外的空间复杂度

感谢各位的阅读,以上就是"JavaScript旋转二维数组的方法"的内容了,经过本文的学习后,相信大家对JavaScript旋转二维数组的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

二维 数组 矩阵 方法 复杂 图像 复杂度 思路 示例 学习 输入 对称 一行 内容 对角 对角线 就是 时针 时间 空间 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 鬼泣巅峰之战服务器装备互通吗 两个数据库共享出现的问题 浪潮机架式服务器选哪家 轻量级服务器部分ip无法连接 定制网络技术开发创新服务 江苏新一代软件开发值得推荐 数据库为什么要用三级模式结构 数据库宏打开三表 数据库中创建默认日期 宁波宁海县靠谱软件开发 河北廊坊网络安全公益广告 孤岛惊魂五多人联机服务器异常 网络安全观后感200字初二作文 网络技术员危险吗 清代知县数据库 王继彬的软件开发教程合集 乐确网络技术有限公司 网络安全业绩最好 法院网络安全周活动总结 个人硬盘如何挂载服务器上 应县电子软件开发招聘网 理财产品数据库 服务器如何读取dtu 金华桌面软件开发自学步骤 浙江省网络安全学院干嘛用的 磁县软件开发招聘信息 柳州网络安全it培训哪家好 日本官方的专利数据库 网络安全信息第一龙头 p2p软件开发公司排名
0