Arrays multidimensionais em C

A linguagem de programação C permite arrays multidimensionais. Aqui está a forma geral de uma declaração de matriz multidimensional -

type name[size1][size2]...[sizeN];

Por exemplo, a seguinte declaração cria uma matriz tridimensional de inteiros -

int threedim[5][10][4];

Arrays bidimensionais

A forma mais simples de matriz multidimensional é a matriz bidimensional. Um array bidimensional é, em essência, uma lista de arrays unidimensionais. Para declarar uma matriz de inteiros bidimensional de tamanho [x] [y], você escreveria algo da seguinte maneira -

type arrayName [ x ][ y ];

Onde type pode ser qualquer tipo de dados C válido e arrayNameserá um identificador C válido. Uma matriz bidimensional pode ser considerada como uma tabela que terá x número de linhas e y número de colunas. Uma matriz bidimensionala, que contém três linhas e quatro colunas podem ser mostradas da seguinte forma -

Assim, cada elemento da matriz a é identificado por um nome de elemento do formulário a[ i ][ j ], onde 'a' é o nome da matriz e 'i' e 'j' são os subscritos que identificam exclusivamente cada elemento em 'a'.

Inicializando matrizes bidimensionais

Matrizes multidimensionais podem ser inicializadas especificando valores entre colchetes para cada linha. A seguir está uma matriz com 3 linhas e cada linha possui 4 colunas.

int a[3][4] = {  
   {0, 1, 2, 3} ,   /*  initializers for row indexed by 0 */
   {4, 5, 6, 7} ,   /*  initializers for row indexed by 1 */
   {8, 9, 10, 11}   /*  initializers for row indexed by 2 */
};

As chaves aninhadas, que indicam a linha pretendida, são opcionais. A inicialização a seguir é equivalente ao exemplo anterior -

int a[3][4] = {0,1,2,3,4,5,6,7,8,9,10,11};

Acessando Elementos de Matriz Bidimensional

Um elemento em uma matriz bidimensional é acessado usando os subscritos, ou seja, índice de linha e índice de coluna da matriz. Por exemplo -

int val = a[2][3];

A instrução acima pegará o 4º elemento da 3ª linha do array. Você pode verificar isso na figura acima. Vamos verificar o programa a seguir, onde usamos um loop aninhado para lidar com uma matriz bidimensional -

#include <stdio.h>
 
int main () {

   /* an array with 5 rows and 2 columns*/
   int a[5][2] = { {0,0}, {1,2}, {2,4}, {3,6},{4,8}};
   int i, j;
 
   /* output each array element's value */
   for ( i = 0; i < 5; i++ ) {

      for ( j = 0; j < 2; j++ ) {
         printf("a[%d][%d] = %d\n", i,j, a[i][j] );
      }
   }
   
   return 0;
}

Quando o código acima é compilado e executado, ele produz o seguinte resultado -

a[0][0]: 0
a[0][1]: 0
a[1][0]: 1
a[1][1]: 2
a[2][0]: 2
a[2][1]: 4
a[3][0]: 3
a[3][1]: 6
a[4][0]: 4
a[4][1]: 8

Conforme explicado acima, você pode ter arrays com qualquer número de dimensões, embora seja provável que a maioria dos arrays que você cria sejam de uma ou duas dimensões.