我似乎无法创建一个可以反转任何大小的2D数组的通用方法。我有以下代码,仅适用于3x3阵列。有没有办法修改此代码以反转任何大小的2D数组?
I need my array to go from:
[ 1 2 3 ]
[ 4 5 6 ]
[ 7 8 9 ]
to:
[ 3 2 1 ]
[ 6 5 4 ]
[ 9 8 7 ]
但是这适用于任何数组大小,而不仅仅是3x3而不仅仅是nxn数组(方阵)。
#include<stdio.h>
#include<string.h>
int main()
{
int r,r2,c,c2,temp;
int rows = 3;
int columns = 3;
int a[rows][columns];
a[0][0] = 1;
a[0][1] = 2;
a[0][2] = 3;
a[1][0] = 4;
a[1][1] = 5;
a[1][2] = 6;
a[2][0] = 7;
a[2][1] = 8;
a[2][2] = 9;
r = 0;
r2 = rows-1;
c = 0;
c2 = columns-1;
while(r<=r2){
while(c<=c2){
temp = a[r][c];
a[r][c] = a[r2][c2];
a[r2][c2] = temp;
c++;
c2--;
}
temp = a[r][c];
a[r][c] = a[r2][c2];
a[r2][c2] = temp;
r++;
r2--;
}
for(r=0;r<3;r++){
for(c=0;c<3;c++){
printf("%d\n",a[r][c]);
}
}
}
答案 0 :(得分:1)
您正在反转数组的每一行。所以编写一个函数来反转作为参数传递给它的数组。
第二个就是,
void swap(int *a, int *b){
int temp = *a;
*a = *b;
*b = temp;
}
void rev(int a[],const int col){
for(size_t i = 0; i < col/2; i++){
swap(&a[i],&a[col-i-1]);
}
}
int main(void){
...
for(size_t i = 0; i < rows; i++)
rev(a[i],columns);
...
return 0;
}
您的代码存在的问题是您自己与您想要达到的目标相矛盾。
你做的第一次交换是在r2,c2
和0,0
之间的这种方式,这是你在交换最后一行和第一行时的第一次迭代。这就是你不想做的事情(至少问题是这样)。