An array of more than one dimension is known as multi-dimensional array. The most commonly used multi-dimensional array is two dimensional array. An array in Java is equivalent to list in Python.

Two-dimensional array (Java) vs Two-dimensional list (Python)

If you know how to create one dimensional array and fact that multi-dimensional arrays are just array of array in Java, then creating a 2 dimensional array should be easy. 

A good representation of a 2-dimensional array (list) is a grid because technically, it is one. A practical application for 2-dimensional lists would be to use them to store the available seats in a cinema, where one dimension represents the rows and other one - columns (seats). Of course, a cinema would be bigger in real life, but this list is just fine as an example. 0 means the seat is available, 1 stands for one that isn't. Later, we could also add 2 for reserved seats and so on.

Array in Java
int[][] cinema = new int[5][5]; 
for (int j = 0; j < cinema.length; j++) {
	for (int i = 0; i < cinema[j].length; i++) {
    	cinema[j][i] = 0;       
    }
}
Instead of one bracket used in one dimensional array, we will use two e.g. int[][] to define two-dimensional array. 

Array in Python
cinema = []
for j in range(5):
	column = []
    for i in range(5):
		Column.append(0)
	Cinema.append(column)

In Python, we declare the 2D array (list) like a list of lists. First, we create an empty one-dimensional list. Then we generate 5 more lists (columns) using a for loop, fill each list with 5 zeros using a nested loop and add the list to the original list as a new item.

The first number indicates the number of columns, the second is the number of rows, we could treat it the other way around as well, for example, matrices in mathematics have the number of rows come first.

We've just created a table full of zeros.

Filling the data

Let's fill the cinema room with 1s now as you can see in the picture bellow. Since we'll be lazy as good programmers should be, we'll use for loops to create a row of 1s. To access an item of the 2D list we have to enter two coordinates.

Filling the array in Java
cinema[2][2] = 1;
for (int i = 1; i < 4 ; i++) {
  	cinema[i][3] = 1; // the fourth row
}
for (int i = 0; i < 5 ; i++) {
    cinema[i][4] = 1; // the last row
}
Filling the array in Python
cinema[2, 2] = 1 # center
for i in range(1, 4): # fourth row
        cinema[i][3] = 1
for i in range(5): # the last row
        cinema[i][4] = 1

The output

We'll print the list using a loop as we did before. We'll need 2 loops for the 2d list, the first one will iterate over columns and the second one over rows). As proper programmers, won't specify the number of rows and columns directly into the loop because it may change in the future. We know the len() function so we can easily ask how many columns is in the outer list and how many items is in the inner one. We have to keep in mind the outer list can be empty.

We'll nest the loops in order so that the outer loop iterates over the rows and the inner one over the columns of the current row. After printing a row, we must break a line. Both loops must have a different control variable.

Output in Java
int cols = cinema.length;
int rows = cinema[0].length;
for (int j = 0; j < cols; j++) {
  	for (int i = 0; i < rows; i++) {
     	System.out.print(cinema[i][j]);
    }
    System.out.println("");
}
Output in Python
cols = len(cinema)
rows = 0
if cols:
	rows = len(cinema[0])
for j in range(rows):
    for i in range(cols):
     	print(cinema[i][j], end = "")
    print()
 

Output in both cases would be:

00000
00000
00100
01110
11111


  • No labels