Don't miss this free $200 USD credit (Only valid for 60 days) on DO, launch your idea now

You have no excuses now, use this free credit to launch your projects now on Digital Ocean.

Table of contents

Don't make this mistake using arrays in Python

Don't make this mistake using arrays in Python

The other day I was solving a kata in codewars , one of the steps of the problem needed a two-dimensional array, in more mundane words: an array of arrays. In Python it is super simple to create a two-dimensional array using the multiplication operator, as if it were numbers.

arr = [0]*5
#[0, 0, 0, 0, 0]

If you have no idea what I’m talking about, I have an excellent resource that can help you a lot: “Inmersion en Python”, totally free and in Spanish

The wrong way to create arrays in Python

Knowing how to create arrays using the multiplication operator, we could think of creating a two-dimensional array as follows:

matrix = [[0]*4]*4
#[[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]]
     #

So far so good, we already have our matrix. But, what if we want to change the second element of the first element of our matrix (I have marked it with a hashtag above).

matrix[0][1] = 3
#[[0, 3, 0, 0], [0, 3, 0, 0], [0, 3, 0, 0], [0, 3, 0, 0]]

What happened? We modified a single element and all of them have been modified. And not only that, but the modified elements always correspond to the second element. Why is it that when we change one element of an array in Python they are all changed?

Why are all the elements of my array changed in Python?

This happens because when Python creates the array, it is not creating 4 different arrays, but it creates only one and copies 4 times the reference to this memory space, so, any change we make is modifying the only array that exists and, as the 4 references point to that array, we see the change reflected in all the arrays.

How to prevent this error?

To prevent this error when creating a two-dimensional matrix.

new_matrix = [[0]*4 for _ in range(4)]
new_matrix[0][1] = 3
# [[0, 3, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]]

In the above code, a new array is created for each element in our list comprehension, ensuring that there are 4 individual arrays and that each change occurs only once in our two-dimensional array.

Now you know that, if in a two-dimensional matrix you are changing all the elements when you modify a single one, you must change the way you generated your matrix.

Eduardo Zepeda
Web developer and GNU/Linux enthusiast. I believe in choosing the right tool for the job and that simplicity is the ultimate sophistication. Better done than perfect. I also believe in the goodness of cryptocurrencies outside of monetary speculation.
Read more