Why linked lists?
13.1. Why linked lists?#
Let’s say we want to store a list of numbers that can decrease or increase. We decide to store the list in an array as follows:
int array[4] = {1, 4, 7};
data:image/s3,"s3://crabby-images/01172/011724adb2d231f4a9f4e73adc16145e04d6cfdf" alt="An array with 3 elements, and one place left for a new element"
To add a new number to the array between two numbers, we can move all numbers on the left by one place and place our new number as follows:
data:image/s3,"s3://crabby-images/3f756/3f756d26555afacca45d89c99af1617ada17bc75" alt="Inserting an element in an array"
To delete a number from the array, we can move all numbers on the right by one place to the left to overwrite the number to be deleted as follows:
data:image/s3,"s3://crabby-images/1d00a/1d00a91e15bdebba7401832ba4c9c712dc8c04e8" alt="Deleting an element from an array"
To insert more numbers that the array size can handle, we have to create a new array, move all numbers to the new array, and then add the new numbers to the array as follows:
data:image/s3,"s3://crabby-images/6d3d5/6d3d539fa78edba34d31ebcd8f7a9e39e9180bee" alt="Extending an array"
However, these operations are all inefficient. The operations require us to move all elements or some to the right or left by one place or to a new array. Arrays are not flexible when it comes to changing the array, because the array elements are stored contiguously – next to each other – in the memory. For example, in the case of adding an element in the array, it would have been easier if we can just add the element in the middle without moving the elements to the right.
In the figure below, we broke down the elements of the array into pieces to form a list of numbers. Each piece is stored any where in the memory (not contiguously as in arrays). We can add a new element in the middle of two elements by just adding the new element in the middle of the two pieces. This is much easier than moving all elements to the right by one place.
data:image/s3,"s3://crabby-images/07d04/07d042826b5b439863ae196c4114dd44fb6ebdbd" alt="Inserting an element in the middle of two elements"
In order to maintain the order of the elements, we need to have links between them to determine the first, last (and everything in between) elements . For example, links between all pieces of our array can look as shown in the figure below.
data:image/s3,"s3://crabby-images/af902/af902b9e9c584e0724cf958c0de15c87d62d1b72" alt="Links between elements"
We can now add a new element in the middle of two elements by changing the links to include the new element as shown in the figure below. This is much easier than moving all elements to the right by one place.
data:image/s3,"s3://crabby-images/75abb/75abb0b0ea49b34e7a3bd244df50007599a3438e" alt="Inserting an element in the middle of two elements"
Fig. 13.1 Deleting an element from the list can be easily done by changing the links as shown in the figure below. This is much easier than moving all elements to the left by one place.#
Extending the list can also be easy by adding a new list to the end of the current list as shown in the figure below. This is much easier than moving all elements to a new array.
data:image/s3,"s3://crabby-images/e24a4/e24a49a846d07fc4e98c89293c7ec3798e6c6df6" alt="Extending a list"
This list of numbers that we linked is called a linked list. It is more flexible to add new elements, delete elements, and extend the list than arrays. We will discuss how to implement a linked list in C in the next section.
Quiz
0 Questions