0

int* array10.000 個を超える int 値を持つ配列 がありますが、各 100 の位置を指したいint ** matrix場合、次のようになることを意味します。これが私がやったことです:
matrix[i][j]iarray[i * 100]

u_int8_t **matrix = (u_int8_t **)malloc(width * sizeof(u_int8_t *));

int width_cr = 0;
for (int i = 0; i < width; i ++) {
    if (i % 100 == 0) {

        u_int8_t *position = matrix[width_cr];
        position = &array[i];
        width_cr ++;           

    }
}

問題は、配列の先頭を指していることです

4

1 に答える 1

2

のアドレスを格納しarray[i]ますmatrix[i / 100]

#define HOW_MUCH_NUMBERS 10000

[...]
{
  int array[HOW_MUCH_NUMBERS];
  int i = 0;
  int **matrix;

  matrix = malloc(sizeof(*matrix) * (HOW_MUCH_NUMBERS / 100));
  while (i < HOW_MUCH_NUMBERS)
  {
    matrix[i / 100] = &array[i];
    i += 100;
  }
  [...]
}
于 2012-09-13T12:53:51.640 に答える