我需要一个可以根据矩阵的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;
}
答案 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;
}
}