LeetCode 48 旋转图像

题目描述

旋转图像

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

解法

  1. 解法1:临时数组

旋转特点:

  • 第一行而言,在旋转后,它出现在倒数第一列的位置;矩阵中的第二行而言,在旋转后,它出现在倒数第二列的位置
  • 以此类推得到规律:对于矩阵中第 i 行的第 j 个元素,在旋转后,它出现在倒数第 i 列的第 j 个位置。
  • 即:对于矩阵中的元素 matrix[row][col],在旋转后,它的新位置为 matrix_new[col][n−row−1]

代码思路:

  • 我们使用一个与 matrix 大小相同的辅助数组 matrix_new ,临时存储旋转后的结果。
  • 然后遍历 matrix中的每一个元素,根据上述规则将该元素存放到 matrix_new中对应的位置。
  • 在遍历完成之后,再将 matrix_new中的结果复制到原数组中即可。

java代码:

class Solution {public void rotate(int[][] matrix) {int n = matrix.length;int[][] matrixNew = new int[n][n];for (int i = 0; i <n; i++) {for (int j = 0; j < n; j++) {matrixNew[j][n-i-1] = matrix[i][j];}}for (int i = 0; i <n; i++) {for (int j = 0; j < n; j++) {matrix[i][j] = matrixNew[i][j];}}}
}

复杂度

  • 时间复杂度:O(N^2), 其中 N 是 matrix的边长
  • 空间复杂度:O(N^2)
  1. 解法2:用翻转代替旋转

思路:先水平轴翻转,再主对角线翻转,证明过程参考:旋转图像官方讲解

java代码:

class Solution {public void rotate(int[][] matrix) {int n = matrix.length;// 水平翻转for (int i = 0; i < n / 2; i++) {for (int j = 0; j < n; j++) {int temp = matrix[i][j];matrix[i][j] = matrix[n - i - 1][j];matrix[n - i - 1][j] = temp;}}// 主对角线翻转for (int i = 0; i < n; i++) {for (int j = 0; j < i; j++) {int temp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = temp;}}}
}

复杂度

  • 时间复杂度:O(N^2), 其中 N 是 matrix的边长
  • 空间复杂度:O(1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/423095.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么检查直线模组的故障?

直线模组可谓是自动化设备中不可或缺的一部分&#xff0c;在自动化设备运行过程中&#xff0c;如果发生直线模组报警故障&#xff0c;往往会导致自动化生产线停下来&#xff0c;造成产量的减少&#xff0c;所以检查直线模组的故障很重要&#xff01; 1、检查外观是否有明显的磨…

8.5跳跃游戏(LC55-M)

算法&#xff1a; 其实跳几步无所谓&#xff0c;关键在于可跳的覆盖范围&#xff01; 不一定非要明确一次究竟跳几步&#xff0c;每次取最大的跳跃步数&#xff0c;这个就是可以跳跃的覆盖范围。 这个范围内&#xff0c;别管是怎么跳的&#xff0c;反正一定可以跳过来。 那…

知识笔记(九十五)———Vue中的导航守卫

直白的说&#xff0c;导航守卫就是路由跳转过程中的一些钩子函数&#xff0c;这些函数能让你在跳转过程中操作一些其他的事儿的时机&#xff0c;这就是导航守卫。 比如最常见的登录权限验证&#xff0c;当用户满足条件时&#xff0c;才让其进入导航&#xff0c;否则就取消跳转…

恒创科技:云服务器配置中的vCPU与物理CPU有啥区别?

​  说到云服务器&#xff0c;您可能经常会遇到vCPU这个词&#xff0c;而且它和物理CPU经常被拿来谈论。尽管它们听起来相似&#xff0c;但两者之间存在显著差异。在本文中&#xff0c;我们将详细讨论云vCPU和物理CPU之间的差异。 物理与虚拟 CPU 和 vCPU 之间最显著的区别在…

游戏渲染管道

高级的渲染步骤是由管道&#xff08;软件架构&#xff09;实现&#xff0c;各个阶段会操作输入流中的数据项&#xff0c;并对输出流产生数据。 管道每个阶段独立于其他阶段&#xff0c;所以管道的最大有点在于非常适合并行化。 渲染管道分为3个概要阶段。但在这里多讲几个阶段…

Maven《四》-- 基于Idea进行Maven工程构建

目录 &#x1f436;4.1 构建概念和构建过程 &#x1f436;4.2 命令方式项目构建 1. &#x1f959;编译&#xff1a;mvn compile 2. &#x1f959;清理&#xff1a;mvn clean 3. &#x1f959;打包&#xff1a;mvn package 4. &#x1f959;安装&#xff1a;mvn install …

第二节 K8S 的架构

第二节 K8S 的架构 K8S 架构图如下: 官方文档: https://kubernetes.io/docs/concepts/architecture/ kube-api-server 是集群的核心&#xff0c; 是k8s中最重要的组件&#xff0c; 因为它是实现声明式api的关键, 整个集群的入口,所有请求都要经过它, api接口服务. kubernetes…

制造业管理软件:为何ERP替代不了MES?

一、ERP和MES的功能区别 ERP是一种综合性的企业管理软件&#xff0c;它涵盖了企业的各个方面&#xff0c;包括财务、采购、库存、销售、人力资源等。它的主要功能是将企业内部的各项业务整合为一个整体进行管理&#xff0c;实现信息共享和协同工作。ERP的主要特点是可以对企业…

街头霸王II神经网络AI训练项目

简介&#xff1a; 该项目通过对街头霸王II进行足够的人工或自动训练&#xff0c;最终生成的神经网络可以让对局双方在AI的掌控下自动进行对局。 要求&#xff1a; 一、MAME版本&#xff1a;MAME01850b-64位 二、ROM版本&#xff1a; “街头霸王Ⅱ加速终极格斗日版”(sf2hfj) …

ESP8266模块双模式(AP+STA)共存同时与电脑及手机进行UDP通信

1.准备工作: 硬件: ESP8266模块 USB连接线: 连接ESP8266模块到电脑 如果电脑没有USB接口,准备一个USB HUB: USB HUB 连接电脑Type-C接口,ESP8266模块连接USB HUB 软件: 安装Arduino IDE 2.2.1 在Arduino IDE中安装esp8266开发板(USB没识别芯片,要安装对应操作系统CH2340或…

k8s集群异常恢复

前提、我自己的k8s采用的是单master节点两个从节点部署&#xff0c;我针对单master情况进行恢复说明 场景一&#xff1a;正常开关虚拟机&#xff0c;可直接重启kubelet进行恢复 1、1、一般重启后三个节点都需要检查&#xff0c;输入命令检查kubelet&#xff1a; systemctl s…

立创EDA学习:PCB布局

目前进度 ESP32最小系统板项目&#xff0c;已完成原理图绘制 点击“更新/转换原理图到PCB” 点击“应用修改” 对应器件的封装就可以对应到PCB中 布局传递 回到原理图&#xff0c;框选每一个模块&#xff0c;“设计-布局传递” 会跳转到PCB界面&#xff0c;可以自己选择放置位…