算法 - 图片旋转问题

问题描述

给定一个代表图片的n x n 的二维矩阵,顺时针旋转图片。
注意:
	需要在原矩阵上进行旋转,而不是新建一个矩阵进行
	达到旋转的效果。
如:
例1:
	[
	  [1,2,3],
	  [4,5,6],
	  [7,8,9]
	],
旋转后,
	[
	  [7,4,1],
	  [8,5,2],
	  [9,6,3]
	]
例2:
	[
	  [ 5, 1, 9,11],
	  [ 2, 4, 8,10],
	  [13, 3, 6, 7],
	  [15,14,12,16]
	], 	
旋转后,
	[
	  [15,13, 2, 5],
	  [14, 3, 4, 1],
	  [12, 6, 8, 9],
	  [16, 7,10,11]
	]

算法描述

为了清楚这个问题,我们先了解下一次旋转过程中每个元
素的变化

旋转前1

旋转前2

假设我们把矩阵分解为四个矩形区域,上述问题
即可看成旋转矩形问题。那么,问题就比较直接
了,咱们可以交叉移动第一个矩形内的元素,旋
转由4个元素组成的模版列表。

代码

public static void rotateMatrix (int[][] matrix) {
     int n = matrix.length;
     for (int i = 0; i < n / 2 + n % 2; i++) {
         for (int j = 0; j < n / 2; j++) {
             int[] tmp = new int[4];
             int row = i;
             int col = j;
             for (int k = 0; k < 4; k++) {
                 tmp[k] = matrix[row][col];
                 int x = row;
                 row = col;
                 col = n - 1 - x;
             }
             for (int k = 0; k < 4; k++) {
                 matrix[row][col] = tmp[(k + 3) % 4];
                 int x = row;
                 row = col;
                 col = n - 1 - x;
             }
         }
     }
 }

复杂度分析

  • 时间复杂度:O(N^2)
  • 空间复杂度:O(1),因为我们就原数组进行旋转, 仅创建了一个临时数组来进行操作。ß
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值