2D数组元素在设置后发生变化

时间:2017-09-27 13:24:14

标签: c arrays multidimensional-array cs50

下面的程序是根据用户输入的维度打印整数的正方形网格(作为edx上哈佛cs50课程的一部分)。

正在初始化数组,但是当打印出来时,最后一列总是打印不正确。我尝试通过在init()函数的最里面的for循环中放入2个printf语句来进行调试。 似乎在最外层循环运行一次之后,最后一列中的条目减1,尽管在此之前它是正确的。

为什么会这样?不能正确打印吗?

#include <stdio.h>

 main()
{
    void init(int dim, int arr[dim-1][dim-1]);
    int dim;
    printf("Enter board dimension(max 10): ");
    scanf("%d", &dim);

    int arr[dim-1][dim-1];

    init(dim, arr);

    int i,j;    
    for(i=0;i<dim;i++)
    {
        for(j=0;j<dim;j++)
        {
            printf("%2d  ",arr[i][j]);
        }
        printf("\n");
    }   
}

void init(int dim, int arr[dim-1][dim-1])
{
    int i,j,p;
    for(i=0;i<dim;i++)
    {
        for(j=0;j<dim;j++)
        {
            arr[i][j] = (dim*dim-1)-i*dim-j;
        }   
            for(p=0;p<dim;p++)
            {
                printf("%d ", arr[i][p]);
                if(i>=1)
                printf("%d ", arr[i-1][p]);
            }   

    }
    printf("\n");
    if(dim%2==0)
    {
        arr[dim-1][dim-3] = 1;
        arr[dim-1][dim-2] = 2;
    }
}

编辑:它应该立即编译

1 个答案:

答案 0 :(得分:0)

您使用a[dim - 1][dim - 1]定义数组,该数组是所需维度的一小部分。如果用户输入“4”,则创建一个3×3阵列。

你的数组是二维的,长度可变。因此,您必须在函数中沿着数组传递维度,至少在最后一个维度上。你这样做是正确的,但是'behaves as if the array were a [dim] [dim] , when it's actually a [dim - 1] [dim - 1]`中的代码。

使用实际维度dim定义数组,并访问索引为0dim - 1的元素。这通常是在这样的循环中完成的:

for (int i = 0; i < dim; i++) ...

看到>=dim - 1类似的东西应该让你警惕。

您的程序现在看起来像这样:

#include <stdio.h>

void init(int dim, int arr[dim-1][dim-1]);
void print(int dim, int arr[dim-1][dim-1]);

int main(void)
{
    int dim;

    printf("Enter board dimension: ");
    scanf("%d", &dim);

    int arr[dim][dim];

    init(dim, arr);
    print(dim, arr);

    return 0;
}

void print(int dim, int arr[dim][dim])
{
    int i,j; 

    for(i = 0; i < dim; i++) {
        for(j = 0; j < dim; j++) {
            printf("%2d  ", arr[i][j]);
        }
        printf("\n");
    }
}

void init(int dim, int arr[dim][dim])
{
    int i, j;

    for(i = 0; i < dim; i++) {
        for(j = 0; j < dim; j++) {
            int ii = dim - 1 - i;
            int jj = dim - 1 - j;

            arr[i][j] = ii*dim + jj;
        } 
    }
}