将接收静态2D数组的函数转换为接收指针的函数

时间:2018-05-22 13:42:22

标签: c arrays pointers multidimensional-array arguments

我有一个在静态存储器中编程的代码(接收静态二维数组的函数)(静态代码不会编译,二维数组没有维度)我需要用指针将其转换为动态内存(接收函数)  指针)。

静态存储器代码是:

void mas_corto(unsigned int c[][], unsigned int a[][], int P[][], unsigned int nNodos)
{
int i,j,k;
for (i = 0; i < nNodos; i++){
    for(j=0; j < nNodos; j++){
        // Inicializamos con el coste de los caminos directos
        A[i][j] = C[i][j]; P[i][j] = -1;
    }
}
for (k = 0; k < nNodos; k++)
    for (i = 0; i < nNodos; i++)
        for (j=0; j< nNodos; j++)
            if (A[i][k]+A[k][j] < A[i][j])
            {
                A[i][j] = A[i][k] + A[k][j];
                P[i][j] = k;
            }
}

void camino (int P[][], int i, int j)
{
int k;
if ((k=P[i][j])== -1)
    return;
camino(i,k);
printf("%d",k);
camino(k,j);
}

#define boolean int
void warshall (boolean c[][], boolean a[][], unsigned int nNodos)
{
int i,j,k;
for (i = 0; i < nNodos; i++)
    for (j=0; j< nNodos; j++)
        A[i][j] = C[i][j];
    for (k = 0; k < nNodos; k++)
        for (i = 0; i < nNodos; i++)
            for (j=0; j< nNodos; j++)
                A[i][j] = A[i][j] || A[i][k] && A[k][j];
}

如您所见,函数接收静态2D静态数组,我需要将它们转换为2D指针,如:

void mas_corto(unsigned int **C, unsigned int **A, int **P, unsigned int nNodos)
{
    // CODE TRANSLATED
}

void camino (int **P, int i, int j)
{
    // CODE TRANSLATED
}

#define boolean int
void warshall (boolean **C, boolean **A, unsigned int nNodos)
{
    // CODE TRANSLATED
}

但我不知道如何将包含在静态函数内的代码转换为指针函数。任何想法我怎么能实现这一目标? (我需要将translate / adpat静态函数内代码转换为指针,换句话说,我需要填充// CODE TRANSLATED出现的地方)

谢谢。

1 个答案:

答案 0 :(得分:3)

实际上你可以使用数组,因为你知道知道大小而C支持可变长度数组。

只需更改参数的顺序,将大小放在第一位,然后就可以在剩下的参数中使用它了:

void mas_corto(unsigned int nNodos, unsigned int c[][nNodos], unsigned int a[][nNodos], int P[][nNodos]) { ... }