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

旋转图像(LeetCode 48)

文章目录

  • 1.问题描述
  • 2.难度等级
  • 3.热门指数
  • 4.解题思路
  • 参考文献

1.问题描述

给定一个 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]]

提示:

n == matrix.length == matrix[i].length
1 <= n <= 20
-1000 <= matrix[i][j] <= 1000

2.难度等级

Medium。

3.热门指数

★★★★☆

4.解题思路

首先我们只能在原矩阵上进行操作,而不可以借助另一个矩阵。其次这是一个特殊的二维矩阵,列数和行数是相等的,通常称之为方阵。所以我们剩下的只需要理清楚怎么旋转90°即可。

在这里插入图片描述
观察上图,我们可以由外到内,一层一层地旋转。

  • 所谓的旋转,实际上是将每一位移动到下一个位置。旋转 90° 即A[0,0]转到A[0,n]位置;A[0,n]转到A[n,n]位置;A[n,n]转到A[n,0]位置;A[n,0]转到A[0,0]位置。

  • 上一步操作的是最外层的一层 环,我们只需要一层层往里执行相同的操作,最终即可完成整个矩阵的旋转。

  • 假设矩阵是 n*n 的,那么我们对 n/2 个环执行旋转即可完成。

  • 对于任一层的环,假设左上角索引为[i, j],那么 j 的终止下标为 n - i - 1。

  • 重点来了,各个元素的交换的下标关系如下

A[i][j] 		由	A[n-j-1][i]		填充
A[n-j-1][i]		由	A[n-i-1][n-j-1]	填充
A[n-i-1][n-j-1]	由	A[j][n-i-1]		填充
A[j][n-i-1] 	由	A[i][j]   		填充

时间复杂度: O(n^2)。其中 n 是矩阵的边长。我们需要移动矩阵的所有元素,除了中间的那个元素。

空间复杂度: O(1)。为原地旋转。

下面以 Golang 为例给出实现。

func rotate(matrix [][]int) {n := len(matrix[0])// 按照层进行循环。for i := 0; i < n/2; i++ {for j := i; j < n-i-1; j++ {tmp := matrix[i][j]matrix[i][j] = matrix[n-j-1][i]matrix[n-j-1][i] = matrix[n-i-1][n-j-1]matrix[n-i-1][n-j-1] = matrix[j][n-i-1]matrix[j][n-i-1] = tmp}}
}// 因为 Golang 支持多重赋值,所以交换可以写成一行。
func rotate(matrix [][]int) {n := len(matrix[0])for i := 0; i < n/2; i++ {for j := i; j < n-i-1; j++ {matrix[i][j], matrix[n-j-1][i], matrix[n-i-1][n-j-1], matrix[j][n-i-1] = matrix[n-j-1][i], matrix[n-i-1][n-j-1], matrix[j][n-i-1], matrix[i][j]}}
}

参考文献

48. 旋转图像 - LeetCode

相关文章:

  • 计算机网络-VLAN原理与配置
  • 跟我学c++中级篇——再谈C++20中的协程
  • leetcode07-罗马数字的转换
  • 盛最多水的容器【双指针】
  • 数据结构OJ实验14-哈希查找
  • Redisson依赖冲突记录
  • STC进阶开发(三)蜂鸣器、RTC时钟、I2C总线、外部中断、RTC闹钟设置、RTC计时器设置
  • C语言——指针
  • 百度吉利合作造车生态,极越“智价比”能否带来科技平权?
  • 数据库管理-第127期 LSM Tree(202301225)
  • openFeign服务调用
  • 惊人技术!重新定义人机互动:深入了解神经链接的脑机接口技术
  • Android studio 花式按键
  • 【AIGC-图片生成视频系列-6】SSR-Encoder:用于主题驱动生成的通用编码器
  • Golang高质量编程与性能调优实战
  • .pyc 想到的一些问题
  • 77. Combinations
  • Javascripit类型转换比较那点事儿,双等号(==)
  • MySQL常见的两种存储引擎:MyISAM与InnoDB的爱恨情仇
  • mysql中InnoDB引擎中页的概念
  • php中curl和soap方式请求服务超时问题
  • Storybook 5.0正式发布:有史以来变化最大的版本\n
  • uni-app项目数字滚动
  • 理解 C# 泛型接口中的协变与逆变(抗变)
  • 理解在java “”i=i++;”所发生的事情
  • 前端工程化(Gulp、Webpack)-webpack
  • 深入体验bash on windows,在windows上搭建原生的linux开发环境,酷!
  • 使用API自动生成工具优化前端工作流
  • 移动端解决方案学习记录
  • nb
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • 数据可视化之下发图实践
  • #if #elif #endif
  • (1)STL算法之遍历容器
  • (10)STL算法之搜索(二) 二分查找
  • (cos^2 X)的定积分,求积分 ∫sin^2(x) dx
  • (HAL库版)freeRTOS移植STMF103
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (十)DDRC架构组成、效率Efficiency及功能实现
  • (转)mysql使用Navicat 导出和导入数据库
  • (转)一些感悟
  • (状压dp)uva 10817 Headmaster's Headache
  • .net CHARTING图表控件下载地址
  • .Net Framework 4.x 程序到底运行在哪个 CLR 版本之上
  • .net解析传过来的xml_DOM4J解析XML文件
  • .vue文件怎么使用_vue调试工具vue-devtools的安装
  • @PreAuthorize注解
  • @Transactional类内部访问失效原因详解
  • @value 静态变量_Python彻底搞懂:变量、对象、赋值、引用、拷贝
  • [BZOJ] 2044: 三维导弹拦截
  • [CentOs7]搭建ftp服务器(2)——添加用户
  • [echarts] y轴不显示0
  • [Excel VBA]单元格区域引用方式的小结
  • [HNOI2008]玩具装箱toy