O(1)空间复杂度实现n*n矩阵旋转90度,

#include <iostream>
using namespace std;

#define ARRAY_SIZE 5

void print_two_array (int a[][ARRAY_SIZE]) {
cout << endl;
   for (int i=0; i<ARRAY_SIZE; i++) {
for (int j=0; j<ARRAY_SIZE; j++) {
   cout << a[i][j] << ",";
}
cout << endl;
}
cout << endl;
}

void in_place_retation (int a[][ARRAY_SIZE]) {
   int swap = 0;
const int n = ARRAY_SIZE;
for (int k=0; k<n/2; k++) {
   for (int i=k; i<n-k-1; i++) {
   swap = a[k][i];
a[k][i] = a[i][n-k-1];
a[i][n-k-1] = a[n-k-1][n-i-1];
a[n-k-1][n-i-1] = a[n-i-1][k];
a[n-i-1][k] = swap;
//print_two_array(a);
}
//print_two_array(a);
}
}

int main () {
int a[ARRAY_SIZE][ARRAY_SIZE] = {
1,2,3,4,5,
6,7,8,9,10,
11,12,13,14,15,
16,17,18,19,20,
21,22,23,24,25
};

print_two_array(a);
in_place_retation(a);

print_two_array(a);
}