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

查看所有标签

猜你喜欢:

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

ggplot2:数据分析与图形艺术

ggplot2:数据分析与图形艺术

哈德利·威克姆 (Hadley Wickham) / 统计之都 / 西安交通大学出版社 / 2013-5-1 / CNY 46.00

中译本序 每当我们看到一个新的软件,第一反应会是:为什么又要发明一个新软件?ggplot2是R世界里相对还比较年轻的一个包,在它之前,官方R已经有自己的基础图形系统(graphics包)和网格图形系统(grid包),并且Deepayan Sarkar也开发了lattice包,看起来R的世界对图形的支持已经足够强大了。那么我们不禁要问,为什么还要发明一套新的系统? 设计理念 打个比......一起来看看 《ggplot2:数据分析与图形艺术》 这本书的介绍吧!

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具