JavaScript旋转二维数组的方法
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要讲解了"JavaScript旋转二维数组的方法",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JavaScript旋转二维数组的方法"吧!一
千家信息网最后更新 2025年01月19日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安全错误
数据库的锁怎样保障安全
Wmn 网络安全产品
金山区企业网络技术服务口碑推荐
广工计算机网络技术实验
10台电脑服务器
温州金牛网络技术
世界著名的心电信号数据库
在履行网络安全监管职责中
舟山安卓软件开发
计算机网络技术常用英语
数据库安全权限语句
服务器snmp使用
自己写的数据库连接池怎么初始化
服务器的ip地址和管理地址
网络安全周活动特色
wps公司软件开发
网络安全设置在哪里设置
数据分析和网络安全
车载酷狗音乐显示服务器错误
电脑初始化数据库
怎么查服务器硬盘故障
双猫软件开发建设
数据库被用户锁住
数据库数据模型的组件包括
服务器系统引导管理
在单位网络安全会议上的讲话
互联网爱科技
web前端软件开发哪家可靠
共建分布式网络安全大脑周鸿祎
网络安全短视频乱扫码危害大
服务器1折