web-dev-qa-db-ja.com

Cでポインタで2D配列を渡す方法は?

私は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" );
    }
}
33
user1362058

char **は2D配列を表しません-ポインターへのポインターの配列になります。 2D配列を渡す場合は、printarrayの定義を変更する必要があります。

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

または同等に:

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

Main()では、変数「配列」は次のように宣言されます

char array[50][50];

これは2500バイトのデータです。 main()の「配列」が渡されるとき、それはそのデータの先頭へのポインタです。これは、50行で構成されると予想されるcharへのポインターです。

それでも、関数printarray()では、宣言します

 char **array

ここでの「配列」は、「char * pointer」へのポインターです。

「void printarray(char array [] [50]、int SIZE)」という@Lucusの提案は機能しますが、SIZEパラメーターmustが50になるという点で一般的ではありません。

アイデア: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次元配列を渡す方が簡単です。

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" );
    }
}
2
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