如何将N x N矩阵旋转90度。我希望它在原地?
答案 0 :(得分:51)
for(int i=0; i<n/2; i++)
for(int j=0; j<(n+1)/2; j++)
cyclic_roll(m[i][j], m[n-1-j][i], m[n-1-i][n-1-j], m[j][n-1-i]);
void cyclic_roll(int &a, int &b, int &c, int &d)
{
int temp = a;
a = b;
b = c;
c = d;
d = temp;
}
注意我还没有对此进行过测试,现在只是现场组成。请在进行任何操作前进行测试。
答案 1 :(得分:9)
这是我的解决方案: (顺时针旋转pi / 2)
进行数组转置(如矩阵转置)
反转每行的元素
cons int row = 10;
cons int col = 10;
//transpose
for(int r = 0; r < row; r++) {
for(int c = r; c < col; c++) {
swap(Array[r][c], Array[c][r]);
}
}
//reverse elements on row order
for(int r = 0; r < row; r++) {
for(int c =0; c < col/2; c++) {
swap(Array[r][c], Array[r][col-c-1])
}
}
如果逆时针旋转pi / 2
转置数组
按列顺序反转元素
永远不会测试代码! 任何建议将不胜感激!
答案 2 :(得分:0)
一个完整的C程序,说明了我的方法。基本上它是递归算法。在每次递归时,您都可以旋转外层。当矩阵为1x1或0x0时停止。
#include <stdio.h>
int matrix[4][4] = {
{11, 12, 13, 14},
{21, 22, 23, 24},
{31, 32, 33, 34},
{41, 42, 43, 44}
};
void print_matrix(int n)
{
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
printf(" %d ", matrix[i][j]);
}
printf("\n");
}
}
int *get(int offset, int x, int y)
{
return &matrix[offset + x][offset + y];
}
void transpose(int offset, int n)
{
if (n > 1) {
for (int i = 0; i < n - 1; i++) {
int *val1 = get(offset, 0, i);
int *val2 = get(offset, i, n - 1);
int *val3 = get(offset, n - 1, n - 1 - i);
int *val4 = get(offset, n - 1 - i, 0);
int temp = *val1;
*val1 = *val4;
*val4 = *val3;
*val3 = *val2;
*val2 = temp;
}
transpose(offset + 1, n - 2);
}
}
main(int argc, char *argv[])
{
print_matrix(4);
transpose(0, 4);
print_matrix(4);
return 0;
}
答案 3 :(得分:0)
//Java version, fully tested
public class Rotate90degree {
public static void reverseElementsRowWise(int[][] matrix) {
int n = matrix.length;
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n / 2; ++j) {
int temp = matrix[i][n - j - 1];
matrix[i][n - j - 1] = matrix[i][j];
matrix[i][j] = temp;
}
}
}
public static void transpose(int[][] matrix) {
int n = matrix.length;
for(int i = 0; i < n; ++i) {
for(int j = i + 1; j < n; ++j) {
int temp = matrix[i][j];
matrix[i][j] = matrix[j][i];
matrix[j][i] = temp;
}
}
}
public static void rotate90(int[][] matrix) {
transpose(matrix);
reverseElementsRowWise(matrix);
}
public static void print(int[][] matrix) {
int n = matrix.length;
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
System.out.print(matrix[i][j]);
System.out.print(' ');
}
System.out.println();
}
}
public static void main(String[] args) {
int[][] matrix = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12},
{13, 14, 15, 16}};
System.out.println("before");
print(matrix);
rotate90(matrix);
System.out.println("after");
print(matrix);
}
}
答案 4 :(得分:-5)
您可以创建第二个数组,然后通过读取第一个数组中的row-major并将column-major写入第二个数组,将第一个数组复制到第二个数组中。
所以你要复制:
1 2 3
4 5 6
7 8 9
然后你会读到第一行然后把它写回来,如:
3
2
1