it-roy-ru.com

Как передать 2D массив по указателю в C?

Я изучаю C, и у меня возникают проблемы при передаче указателя 2D-массива в другую функцию, которая затем печатает 2D-массив. Любая помощь будет оценена. 

int main( void ){
    char array[50][50];
    int SIZE;

    ...call function to fill array... this part works.

    printarray( array, SIZE );
}

void printarray( char **array, int SIZE ){
    int i;
    int j;

    for( j = 0; j < SIZE; j++ ){
        for( i = 0; i < SIZE; i ++){
            printf( "%c ", array[j][i] );
        }
        printf( "\n" );
    }
}
32
user1362058

char ** не представляет двумерный массив - это будет массив указателей на указатели. Вам нужно изменить определение printarray, если вы хотите передать ему 2D-массив:

void printarray( char (*array)[50], int SIZE )

или эквивалентно:

void printarray( char array[][50], int SIZE )
24
Carl Norum

В main () переменная «массив» объявляется как 

char array[50][50];

Это 2500 байт данных. Когда передается «массив» main (), это указатель на начало этих данных. Это указатель на символ, который должен быть разбит на 50 строк.

Еще в функции printarray () вы объявляете

 char **array

«массив» - это указатель на «char * pointer».

@Lucus предлагает «void printarray (char array [] [50], int SIZE)», за исключением того, что оно не является универсальным в том смысле, что ваш параметр SIZE должен будет 50.

Идея: Defat (yeech) тип массива параметров в printarray ()

void printarray(void *array, int SIZE ){
    int i;
    int j;
    char *charArray = (char *) array;

    for( j = 0; j < SIZE; j++ ){
        for( i = 0; i < SIZE; i ++){
            printf( "%c ", charArray[j*SIZE + i] );
        }
        printf( "\n" );
    }
}

Более элегантное решение состоит в том, чтобы сделать "массив" в main () массивом указателей.

// Your original printarray()
void printarray(char **array, int SIZE ){
    int i;
    int j;
    for( j = 0; j < SIZE; j++ ){
        for( i = 0; i < SIZE; i ++){
            printf( "%c ", array[j][i] );
        }
        printf( "\n" );
    }
}

// main()
char **array;
int SIZE;
// Initialization of SIZE is not shown, but let's assume SIZE = 50;
// Allocate table
array = (char **) malloc(SIZE * sizeof(char*));
  // Note: alternative syntax
  // array = (char **) malloc(SIZE * sizeof(*array));
// Allocate rows
for (int row = 0; row<SIZE; row++) {
  // Note: sizeof(char) is 1. (@Carl Norum)
  // Shown here to help show difference between this malloc() and the above one.
  array[row] = (char *) malloc(SIZE * sizeof(char));
    // Note: alternative syntax
    // array[row] = (char *) malloc(SIZE * sizeof(**array));
  }
// Initialize each element.
for (int row = 0; row<SIZE; row++) {
  for (int col = 0; col<SIZE; col++) {
    array[row][col] = 'a';  // or whatever value you want
  }
}
// Print it
printarray(array, SIZE);
...
5
chux

Поскольку C99 поддерживает массивы динамического размера, следующий стиль просто удобнее для передачи массива 2-dim:

void printarray( void *array0, int SIZE ){
    char (*array)[SIZE] = array0;
    int i;
    int j;
    for( j = 0; j < SIZE; j++ ){
        for( i = 0; i < SIZE; i ++){
            printf( "%c ", array[j][i] );
        }
        printf( "\n" );
    }
}
1
Simon Woo

Вы можете легко передать 2d массив, используя двойной указатель.

  void printarray( char **array, int n)
  {
     int i, j;
     for(i=0; i<n; i++ )
     {
         for(j=0; j<n; j++)
         {
            printf("%c ", array[i][j] );
         }
        printf( "\n" );
     }
  }

  int main()
  {
      int n = 2;
      int i, j;

      char **array = (char **) malloc(n * sizeof(char*));

      for (i=0; i<n; i++) 
      {
        array[i] = (char *) malloc(n* sizeof(char));
      }

     for (i=0; i<n; i++)
     {
       for (j=0; j<n; j++)
       {
           scanf("%c ", &array[i][j]);
       }
     }

     printarray(array, n);

     return 0;
  }

Полный код: Ideone

0
rashedcs