48. Rotate Image

栏目: Java · 发布时间: 5年前

内容简介:You are given an n x n 2D matrix representing an image.Rotate the image by 90 degrees (clockwise).Note:

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]
]

难度: medium

题目:给定n * n的矩阵表示一张图片。顺时针90度旋转。

注意:必须原地旋转不允许申请额外的空间。

思路:90度旋转有数学规律可寻。

Runtime: 1 ms, faster than 100.00% of Java online submissions for Rotate Image.

Memory Usage: 26.4 MB, less than 46.19% of Java online submissions for Rotate Image.

class Solution {
    public void rotate(int[][] matrix) {
        int n = matrix.length;
        int nIdx = n - 1;
        for (int i = 0; i < n / 2; i++) {
            int start = i;
            int end = nIdx - i;
            for (int j = start; j < end; j++) {
                int t = matrix[nIdx - j][i];
                matrix[nIdx - j][i]= matrix[end][nIdx - j];
                matrix[end][nIdx - j] = matrix[j][end];
                matrix[j][end] = matrix[i][j];
                matrix[i][j] = t;
             }
        }
    } 
}

以上所述就是小编给大家介绍的《48. Rotate Image》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

微交互

微交互

塞弗 (Dan Saffer) / 李松峰 / 人民邮电出版社 / 2013-11-1 / 35.00元

平庸的产品与伟大的产品差就差在细节上。作者Dan Saffer将通过这本书展示怎么设计微交互,即位于功能之内或周边的那些交互细节。你的手机怎么静音?你怎么知道有新邮件了?怎么修改应用的设置?诸如此类的交互细节,既可以毁掉一个产品,也可以成就一个产品。高效而有趣的微交互 ,涉及触发器、规则、循环和模式,还有反馈。透过书中生动、真实的设备及应用示例,读者将理解微交互对于塑造产品个性、赋予产品卖点的重要......一起来看看 《微交互》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

MD5 加密
MD5 加密

MD5 加密工具