旋转正方形矩阵
【题目】 给定一个整型正方形矩阵matrix,请把该矩阵调整成顺时针旋转90度的样子。
【要求】 额外空间复杂度为O(1)。
/*
* 顺时针旋转正方形矩阵90°
* 分圈旋转,每次完成一圈,重点在于边界抠清楚
*/
public class 旋转正方形矩阵 { public static void rotate(int[][] matrix) { int a = 0; int b = 0; int c = matrix.length - 1; int d = matrix[0].length - 1; while (b < d) { rotateEdge(matrix, a++, b++, c--, d--); } } private static void rotateEdge(int[][] matrix, int a, int b, int c, int d) { int times = d - b; int temp = 0; for(int i = 0; i != times;i++) { temp = matrix[a][b+i]; matrix[a][b+i] = matrix[c-i][b]; matrix[c-i][b] = matrix[c][d-i]; matrix[c][d-i] = matrix[a+i][d]; matrix[a+i][d] = temp; } } public static void printMatrix(int[][] matrix) { for (int i = 0; i != matrix.length; i++) { for (int j = 0; j != matrix[0].length; j++) { System.out.print(matrix[i][j] + " "); } System.out.println(); } } public static void main(String[] args) { // TODO Auto-generated method stub int[][] matrix = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 }, { 9, 10, 11, 12 }, { 13, 14, 15, 16 } }; printMatrix(matrix); rotate(matrix); System.out.println("========="); printMatrix(matrix); } }