48. Rotate Image

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

内容简介: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》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

计算机程序设计艺术(第3卷)-排序和查找(英文影印版)

计算机程序设计艺术(第3卷)-排序和查找(英文影印版)

(美)Donald E.Knuth / 清华大学出版社 / 2002-9 / 85.00元

《计算机程序设计艺术排序和查找(第3卷)(第2版)》内容简介:这是对第3卷的头一次修订,不仅是对经典计算机排序和查找技术的最全面介绍,而且还对第1卷中的数据结构处理技术作了进一步的扩充,通盘考虑了将大小型数据库和内外存储器。它遴选了一些经过反复检验的计算机方法,并对其效率做了定量分析。第3卷的突出特点是对“最优排序”一节作了修订,对排列论原理与通用散列法作了全新讨论。一起来看看 《计算机程序设计艺术(第3卷)-排序和查找(英文影印版)》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具