LeetCode:旋转图像
题目描述
给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。
你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。
作者:力扣 (LeetCode)
链接:https://leetcode-cn.com/leetbook/read/top-interview-questions-easy/xnhhkv/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
题目解析
例,输入输出如下图:

这个题目与其说是一道算法题,不如说是一道找规律得题目,我们怎样才能实现图像得90度旋转呢?通过对比输入输出图中数字得位置可以发现:我们可以将第一列得4个数通过顺时针旋转到第一行上,第一行顺时针旋转到最后一列上,一次类推;内圈的数字也要如此旋转,就可以完成题目要求,如下图:

有了思路之后,我们怎么通过算法实现呢?那就是找规律了。
首先,我们以数字5为例,看一下它以及和他有关的数字的变化路径:5->11 11->16 16->15 15->5;
其次,我们继续找规律,我们将上述数字集合线标来一遍:
5(0,0)->11(0,3)
11(0,3)->16(3,3)
16(3,3)->15(3,0)
15(3,0)->5(0,0)
从下标中我们能够发现有重复的下标相互转换数字,那么他们其中有什么内在的连续呢?我们现在找规律已经使用了数字转换流程,数字的下标,仔细想一下我们是不是还有一个关键的变量没有用到,那就是n*n;
最后,我们加上二维数组的行列长度再来一遍:
5([i]:0,[j]:0)->11([i]:0,[n-i或者j-1]:3)
11()
写到第二条的时候我发现写不下去了,这里的下标有大量的0和3,没有办法分辨是i还是j,写出来的规律也不能通用,因此我决定用数字1及其相关的数字类找规律(i=0,j=1)
首先,
1->10
10->12
12->13
13->1
其次,
1(0,1)->10(1,3)
10(1,3)->12(3,2)
12(3,2)->13(2,0)
13(2,0)->(0,1)
最后,
1([i]:0,[j]:1)->10([j]:1,[n-i-1]:3)
10([j]:1,[n-i-1]:3)->12([n-i-1]:3,[n-j-1]:2)
12([n-i-1]:3,[n-j-1]:2)->13([n-j-1]:2,[i]:0)
13([n-j-1]:2,[i]:0)->1([i]:0,[j]:1)
我们找到一下通用变量,有兴趣的可以套一下数字9及其相关数字的规律:
令:int m=n-i-1,c=n-j-1。
如下图示:

题目解答
算法1,时间复杂度为 o(n²),直接上代码如下:
class Solution {
public:
void rotate(vector<vector<int>>& matrix) {
int row=matrix.size();
int colunm=matrix[0].size();
int length=row/2;
for(int i=0;i<length;i++)
{
for(int j=i;j<colunm-i-1;j++)
{
int m=row-i-1;
int n=row-j-1;
int temp=matrix[i][j];
matrix[i][j]=matrix[n][i];
matrix[n][i]=matrix[m][n];
matrix[m][n]=matrix[j][m];
matrix[j][m]=temp;
}
}
}
};
解题思路:解题思路再题目分析中已经详细阐明,此次不再累述。
LeetCode:旋转图像的更多相关文章
- LeetCode:旋转图像【48】
LeetCode:旋转图像[48] 题目描述 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使 ...
- 前端与算法 leetcode 48. 旋转图像
目录 # 前端与算法 leetcode 48. 旋转图像 题目描述 概要 提示 解析 解法一:转置加翻转 解法二:在单次循环中旋转 4 个矩形 算法 传入测试用例的运行结果 执行结果 GitHub仓库 ...
- LeetCode——48. 旋转图像
给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 1: 给定 m ...
- LeetCode初级算法之数组:48 旋转图像
旋转图像 题目地址:https://leetcode-cn.com/problems/rotate-image/ 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: ...
- [LeetCode] Rotate Image 旋转图像
You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...
- LeetCode 48. Rotate Image(旋转图像)
You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...
- python(leetcode)-48旋转图像
给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 1: 给定 m ...
- LeetCode(48):旋转图像
Medium! 题目描述: 给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转 ...
- Leetcode题库——48.旋转图像
@author: ZZQ @software: PyCharm @file: rotate.py @time: 2018/11/16 15:41 要求:给定一个 n × n 的二维矩阵表示一个图像.将 ...
随机推荐
- [转]DDR3基本概念5 - DDR仿真中出现的Memory overflow错误的处理
ERROR: Memory overflow. Write to Address 7000fe with data xxxxxxxxxxxxxxxx4634899aabe03499 will be l ...
- usb设备无法识别
之前用飞线用旧板子飞线连接了一个wifi模块到usb0口上,调试ok的,现在新设计的板子回来了,wifi模块是连接在usb2口上的,系统起来后发现wlan0不存在,用lsusb查看wifi模块的usb ...
- Spring Cloud Alibaba 使用RestTemplate进行服务消费
创建服务提供者工程 创建spring-cloud-alibaba-service-member工程,会员中心服务该服务提供用户会员信息. pom.xml <?xml version=" ...
- (四)FastDFS 高可用集群架构学习---后期运维--基础知识及常用命令
1.fastdfs 七种状态 FDFS_STORAGE_STATUS:INIT :初始化,尚未得到同步已有数据的源服务器 FDFS_STORAGE_STATUS:WAIT_SYNC :等待同步,已得到 ...
- python环境搭建、pycharm安装
一. 实验目标 (1) Python环境搭建 (2) 会pycharm安装和使用 (3) 了解python程序设计流程 二. 实验内容 1.勾选Add Python 3.7 ...
- 重装系统——联想window 10
大四了,读了四年大学,唉,混的,啥也不会,工作也找不到,真的不知道这大学四年到底干了什么.专业是计算机方向的,但居然,不敢,也不会装电脑系统,大学四年的文件都是乱放的,更那个的是,有些软件卸载不完全, ...
- 【完虐算法】LeetCode 接雨水问题,全复盘
大家好! 动态规划题目是总结的比较完整了.下面是自从和大家刷开题总结的动态规划解题方法. 今年全国夏天雨是真的多,突然想到今年北京的夏天也不像往年那么热.不知不觉就稳稳地度过了夏天来到秋天. 恰巧前几 ...
- Java使用iText7生成PDF
前言 我们之前使用js库html2canvas + jspdf实现html转PDF.图片,并下载(详情请戳:html页面转PDF.图片操作记录),大致原理是将页面塞到画布里,以图片的方式放到PDF中, ...
- java中lamda表达式用法
map-> list Map<String, Object> map = new HashMap<>(); List<String> list = new A ...
- R语言中文分词包jiebaR
R语言中文分词包jiebaR R的极客理想系列文章,涵盖了R的思想,使用,工具,创新等的一系列要点,以我个人的学习和体验去诠释R的强大. R语言作为统计学一门语言,一直在小众领域闪耀着光芒.直到大数据 ...