Matrizes multidimensionais em Objective-C

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

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

Por exemplo, a declaração a seguir cria uma matriz de inteiros 5, 10, 4 tridimensional -

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

Arrays bidimensionais

A forma mais simples do array multidimensional é o array 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 Objective-C válido e arrayNameserá um identificador Objective-C válido. Uma matriz bidimensional pode ser pensada 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 como abaixo -

Assim, cada elemento na matriz a é identificado por um nome de elemento do formulário a[ i ][ j ], onde a é o nome da matriz ei 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 um array bidimensional é acessado usando os subscritos, ou seja, o índice da linha e o índice da coluna do array. Por exemplo -

int val = a[2][3];

A instrução acima pegará o 4º elemento da 3ª linha da matriz. Você pode verificar isso no diagrama acima. Vamos verificar o programa abaixo onde usamos loop aninhado para lidar com uma matriz bidimensional -

#import <Foundation/Foundation.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++ ) {
         NSLog(@"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 -

2013-09-14 01:28:20.458 demo[32018] a[0][0] = 0
2013-09-14 01:28:20.458 demo[32018] a[0][1] = 0
2013-09-14 01:28:20.458 demo[32018] a[1][0] = 1
2013-09-14 01:28:20.458 demo[32018] a[1][1] = 2
2013-09-14 01:28:20.458 demo[32018] a[2][0] = 2
2013-09-14 01:28:20.458 demo[32018] a[2][1] = 4
2013-09-14 01:28:20.458 demo[32018] a[3][0] = 3
2013-09-14 01:28:20.458 demo[32018] a[3][1] = 6
2013-09-14 01:28:20.458 demo[32018] a[4][0] = 4
2013-09-14 01:28:20.458 demo[32018] 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.