Language: EN

que-es-un-array

What is and how to use arrays

Arrays are the simplest possible collection type. They are structures that store a series of elements of the same type and whose number of elements is fixed.

We can think of an ARRAY as an ordered sequence of boxes, where each box contains a specific value.

curso-programacion-array

Representation of the Array in memory

Each element in an ARRAY has a unique position called an index, which is used to directly access that element. For example, this is how we would access the element 06.

curso-programacion-array-1

Access to position 06 of the array

This means we can quickly access any element in the array without having to traverse all the previous elements.

ARRAYS are very efficient collections in terms of space usage, and they offer quick access to elements.

When to use an Array

The main use of ARRAYS is to handle a fixed number of elements. It is mainly suitable for transferring and storing data between parts of the program.

For example, imagine a function getStudents() that returns a collection with the students of a course. The students are what they are, let’s say 27.

I don’t want you to add or remove students, because they are what they are. So I return a ARRAY of fixed length. Then you can do whatever you want with it.

On the other hand, to work with a collection, it is normal to use a Dynamic Array, which is a “better” and much more versatile version. But to exchange collections, it is better to use an array.

Properties of Arrays

PropertyList
Frequency of use🔺🔺
Is mutable
Is ordered✔️
Is indexable✔️
Allows duplicates✔️

Examples of Arrays in different languages

An array has a fixed size, so it is not possible to perform many actions. Basically, with an array we can:

  • Create them
  • Read an element at a position
  • Modify an element at a position
  • Get the length

Create an array

The syntax to declare an array varies depending on the programming language we are using. Let’s see examples in some popular languages,

int[] numbers = new int[5];
int numbers[5];
let numbers = [1, 2, 3, 4, 5];
names = [1, 2, 3, 4, 5]

In the previous examples, in the case of C# and C++, we created arrays that can store a maximum of 5 elements.

However, not all languages have fixed-size arrays. For example, in the case of JavaScript and Python, these arrays will be of dynamic size.

Accessing and manipulating elements

Once we have declared an array, we can access and manipulate its elements using indices.

In most programming languages, indices start at 0. This means that:

  • The first element has an index of 0
  • The second has an index of 1
  • And so on…

To access one of the elements, we generally use the [] operator. Let’s see some examples

int firstElement = numbers[0]; // Accesses the first element
int thirdElement = numbers[2]; // Accesses the third element
auto firstElement = numbers[0]; // Accesses the first element
auto thirdElement = numbers[2]; // Accesses the third element
let firstElement = numbers[0]; // Accesses the first element
let thirdElement = numbers[2]; // Accesses the third element
firstElement = numbers[0]; 'Accesses the first element
thirdElement = numbers[2]; 'Accesses the third element

At first, it will be hard to get used to accessing elements starting from 0. Don’t worry, you’ll quickly get the hang of it.

Modifying elements of an Array

numbers[0] = 10; // Modifies the first element of the array
numbers[2] = 20; // Modifies the third element of the array
numbers[0] = 10; // Modifies the first element of the array
numbers[2] = 20; // Modifies the third element of the array
numbers[0] = 10; // Modifies the first element of the array
numbers[2] = 20; // Modifies the third element of the array
numbers[0] = 10; 'Modifies the first element of the array
numbers[2] = 20; 'Modifies the third element of the array

Length of an Array

In many cases, we need to know the number of elements contained in an array. To obtain the length, we can use the corresponding function or property depending on the programming language:

var length = numbers.Length;

Arrays in C++ do not have a “length” property! I hope you remember the number you set when you created it 😊!

const int ARRAY_SIZE = 5;
int numbers[ARRAY_SIZE];
let length = numbers.length;
length = len(names)

Efficiency of Arrays Intermediate

A ARRAY is a data structure that stores elements contiguously in memory. Reading an element from an array is very efficient, as it can be accessed directly through its index in constant time O(1).

Insertion and deletion of elements do not exist as an operation because an array has a fixed size.

On the other hand, searching requires traversing all elements in the worst case, which also has a linear time complexity O(n).

OperationArray
Sequential access🟢
Random access🟢
Add at the beginning
Remove from the beginning
Add at the end🟢
Remove from the end🟢
Random insertion
Random removal
Search🔴

Internal workings span[Advanced]{.label .red}

When working with a ARRAY, the elements are generally reserved in a contiguous area of memory.

When creating the new array (which can occur at compile time or runtime), the compiler or interpreter reserves the necessary memory.

We know that the size of an array is fixed. On the other hand, the memory size needed to store each element is known by its type. So the interpreter or compiler knows how much memory is needed.

curso-programacion-array-0

Memory access via index in the array

From there, the “name” of the array is an alias to the header or first element of the array.

When we access element 6, for example, the computer simply has to go to memory, where the first element is, and move 6 positions. For this, it logically takes into account the size of the stored element.

These operations are very simple, and computers are highly optimized to perform them. That’s why arrays are so efficient.