[LeetCode] 48. Rotate Image 旋转图像
You are given an n x n 2D matrix representing an image.
Rotate the image by 90 degrees (clockwise).
Note:
You have to rotate the image in-place, which means you have to modify the input 2D matrix directly. DO NOT allocate another 2D matrix and do the rotation.
Example 1:
Given input matrix =
[
[1,2,3],
[4,5,6],
[7,8,9]
], rotate the input matrix in-place such that it becomes:
[
[7,4,1],
[8,5,2],
[9,6,3]
]
Example 2:
Given input matrix =
[
[ 5, 1, 9,11],
[ 2, 4, 8,10],
[13, 3, 6, 7],
[15,14,12,16]
], rotate the input matrix in-place such that it becomes:
[
[15,13, 2, 5],
[14, 3, 4, 1],
[12, 6, 8, 9],
[16, 7,10,11]
]
在计算机图像处理里,旋转图片是很常见的,由于图片的本质是二维数组,所以也就变成了对数组的操作处理,翻转的本质就是某个位置上数移动到另一个位置上,比如用一个简单的例子来分析:
                
      -->         
               
对于90度的翻转有很多方法,一步或多步都可以解,先来看一种直接的方法,这种方法是按顺时针的顺序去覆盖前面的数字,从四个顶角开始,然后往中间去遍历,每次覆盖的坐标都是同理,如下:
(i, j) <- (n-1-j, i) <- (n-1-i, n-1-j) <- (j, n-1-i)
这其实是个循环的过程,第一个位置又覆盖了第四个位置,这里i的取值范围是 [0, n/2),j的取值范围是 [i, n-1-i),至于为什么i和j是这个取值范围,为啥i不用遍历 [n/2, n),若仔细观察这些位置之间的联系,不难发现,实际上j列的范围 [i, n-1-i) 顺时针翻转 90 度,正好就是i行的 [n/2, n) 的位置,这个方法每次循环换四个数字,如下所示:
          -->             -->          
                                    
解法一:
class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = ; i < n / ; ++i) {
            for (int j = i; j < n -  - i; ++j) {
                int tmp = matrix[i][j];
                matrix[i][j] = matrix[n -  - j][i];
                matrix[n -  - j][i] = matrix[n -  - i][n -  - j];
                matrix[n -  - i][n -  - j] = matrix[j][n -  - i];
                matrix[j][n -  - i] = tmp;
            }
        }
    }
};
还有一种解法,首先以从对角线为轴翻转,然后再以x轴中线上下翻转即可得到结果,如下图所示(其中蓝色数字表示翻转轴):
           9  6            7  4  1
      -->          -->     8  5  2  
             4  1          9  6  3
解法二:
class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = ; i < n - ; ++i) {
            for (int j = ; j < n - i; ++j) {
                swap(matrix[i][j], matrix[n - - j][n -  - i]);
            }
        }
        reverse(matrix.begin(), matrix.end());
    }
};
最后再来看一种方法,这种方法首先对原数组取其转置矩阵,然后把每行的数字翻转可得到结果,如下所示(其中蓝色数字表示翻转轴,Github 上可能无法显示颜色,请参见博客园上的帖子):
             4  7              
      -->          -->           
           3  6                 
解法三:
class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = ; i < n; ++i) {
            for (int j = i + ; j < n; ++j) {
                swap(matrix[i][j], matrix[j][i]);
            }
            reverse(matrix[i].begin(), matrix[i].end());
        }
    }
};
Github 同步地址:
https://github.com/grandyang/leetcode/issues/48
参考资料:
https://leetcode.com/problems/rotate-image/
https://leetcode.com/problems/rotate-image/discuss/18895/Clear-Java-solution
https://leetcode.com/problems/rotate-image/discuss/18872/A-common-method-to-rotate-the-image
LeetCode All in One 题目讲解汇总(持续更新中...)
[LeetCode] 48. Rotate Image 旋转图像的更多相关文章
- leetCode 48.Rotate Image (旋转图像) 解题思路和方法
		Rotate Image You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees ... 
- [leetcode]48. Rotate Image旋转图像
		You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ... 
- [array] leetcode - 48. Rotate Image - Medium
		leetcode - 48. Rotate Image - Medium descrition You are given an n x n 2D matrix representing an ima ... 
- LeetCode 48. 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(2D图像旋转问题)
		题目链接: https://leetcode.com/problems/rotate-image/?tab=Description Problem:给定一个n*n的二维图片,将这个二维图片按照顺时 ... 
- [leetcode 48] rotate image
		1 题目 You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwi ... 
- LeetCode 48. Rotate Image My Submissions Question (矩阵旋转)
		题目大意:给一个矩阵,将其按顺时针旋转90°. 题目分析:通法是先将矩阵转置,然后再反转每一行,或者是先反转每一列,然后再将其转置.I just want to say"It's amazi ... 
- LeetCode 48. Rotate Image (C++)
		题目: You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwis ... 
- 【刷题笔记】LeetCode 48. Rotate Image
		题意 原地顺时针翻转一个 n*n 的矩阵 图解 下面例子中用 5*5 矩阵做示例,如下图,我们要把该矩阵顺时针翻转90度,并且不能使用另外的矩阵空间来暂存数据,而是原地改变矩阵中数值. 我的想法是这样 ... 
随机推荐
- python 多进程和多线程对比
			1. 对于耗费CPU的操作来说,多进程优于多线程 2. 对于耗费IO操作来说,多线程优于多进程 3. 多进程切换代价大于多线程 
- react 练习参考
			项目地址:https://gitee.com/dhclly/icedog.react React 练习项目 相关资源链接 React官方 https://reactjs.org React 中国 ht ... 
- 镭神激光雷达对于Autoware的适配
			1. 前言 我们的自动驾驶采用镭神激光雷达,在使用Autoware的时候,需要对镭神激光雷达的底层驱动,进行一些改变以适配Autoware. 2. 修改 (1)首先修改lslidar_c32.laun ... 
- SSM手动实现分页逻辑---非PageHelper方式
			第一种方法:查询出所有数据再分页 分析: 分页时,需要获得前台传来的两个参数,分别为pageNo(第几页数据),pageSize(每页的条数); 根据这两个参数来计算出前端需要的数据是查出数据list ... 
- F#周报2019年第19期
			新闻 介绍.NET 5 发布.NET Core 3.0预览版5以及F#的REPL OpenFsharp CFP开启 F#的Giraffe服务端stub生成器被添加到openapi-generator中 ... 
- 程序基于InstallShield2013LimitedEdition的安装和部署
			在VS2012之前,我们做安装包一般都是使用VS自带的安装包制作工具来创建安装包的,VS2012.VS2013以后,微软把这个去掉,集成使用了InstallShield进行安装包的制作了,虽然思路差不 ... 
- WPF通过不透明蒙板切割显示子控件
			版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/Backspace110/article/ ... 
- 小鸟初学Shell编程(八)环境变量、预定义变量与位置变量
			环境变量 环境变量:每个Shell打开都可以获得到的变量. 我们知道通过export的方式打开可以让子进程读取父进程的变量的值,那怎么样才能让每一个进程都能读取到变量的值呢? 在这呢,系统有一些默认的 ... 
- Vue笔记--同局域网下访问本地项目
			正常开发中有时间提测比较麻烦.通常让测试小姐姐连接开发本地开启的服务器访问本地项目(在同一局域网下). 其实一般项目IDE已经实现这些功能例如webstorm和vscode,有时候需要单独配置下. 但 ... 
- X264-应用工程
			接下来的几篇博客中,具体学习下X264的实现过程. 源代码的分析参考了雷神的博客,感谢雷神!博客链接:https://blog.csdn.net/leixiaohua1020/article/deta ... 
