在C

时间:2018-01-31 03:48:07

标签: c arrays methods 2d reverse

我似乎无法创建一个可以反转任何大小的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]);
        }
    }
}

1 个答案:

答案 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,c20,0之间的这种方式,这是你在交换最后一行和第一行时的第一次迭代。这就是你不想做的事情(至少问题是这样)。