如何根据矩阵的x轴对称性进行设置

时间:2013-05-11 11:26:00

标签: c++ function matrix dynamic-memory-allocation

我需要一个可以根据矩阵的x轴对称的函数。

输入(matrix [i] [j]):

1 2 3
4 5 6
7 8 9

输出(matrix [i] [j]):

7 8 9
4 5 6
1 2 3

我如何在同一个矩阵上执行此操作? 我该如何编写反函数?

void inverse(.......)
 {
 ..
 ..
 ..
 }

int main(){
int **matrix, i, j, k, row, column;
cout << "Row and column:" ;
cin >> row >> column;
matrix = new int*[row];
for (i=0; i<row; ++i){
    matrix[i] = new int[column];
}
cout << "input elements of matrix: " << endl;
for(i=0; i<row; i++){
         for (j=0; j<column; j++){
             cin >> *(*(matrix+i)+j);
         }
}  

inverse (........);

for(i=0; i<row; i++){
         for (j=0; j<column; j++){
             cout << *(*(matrix+i)+j);
         }
         cout << endl;
}  
return 0;
}

1 个答案:

答案 0 :(得分:0)

在这种特殊情况下,您可以修改循环以向后打印矩阵:

for(i = 0; i < row; i++) {

- &GT;

for(i = row - 1; i >= 0; i--) {

但是如果你想真正对数据做些什么,我的建议是重构这段代码以使用std::vector

std::vector<std::vector<int> > matrix(numberOfRows, std::vector<int>(numberOfColumns));
// You can use std::vector<std::valarray<int> > matrix; alternatively.

然后,您只需使用STL函数即可将其翻转:

std::reverse(matrix.begin(), matrix.end());

修改
好吧,如果你暂时不想使用std::vector,对于这个特殊情况,你会做的是:

void flipMatrix(int** matrix, int rows, int columns) {
    int middle = rows/2; // I expect it to truncate for an odd number of rows.

    // Temporary row for swapping
    int* tempRow;

    for (int i = 0; i < middle; i++) {
        // swap rows
        tempRow = matrix[i];
        matrix[i] = matrix[rows - i - 1];
        matrix[rows - i - 1] = tempRow;
    }
}