我有一个在静态存储器中编程的代码(接收静态二维数组的函数)(静态代码不会编译,二维数组没有维度)我需要用指针将其转换为动态内存(接收函数) 指针)。
静态存储器代码是:
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
出现的地方)
谢谢。
答案 0 :(得分:3)
实际上你可以使用数组,因为你知道知道大小而C支持可变长度数组。
只需更改参数的顺序,将大小放在第一位,然后就可以在剩下的参数中使用它了:
void mas_corto(unsigned int nNodos, unsigned int c[][nNodos], unsigned int a[][nNodos], int P[][nNodos]) { ... }