Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Leer Basic Array Operations Time Complexity | List and Array
Algorithms and Data Structures Overview

bookBasic Array Operations Time Complexity

The next table shows the time complexity of basic operations for arrays.

Search operation

As we discussed previously and as it can be seen from the above, the main advantage of the array is that we can access an arbitrary item in constant time if we know the index of that item in an array. But if we don't know what item we are looking for, the lookup operation takes O(N) time complexity as we must provide a Linear Search for an element.

def search_array(arr, target):
    
    return np.any(arr == target)

Delete operation

If we want to delete an item by index, we can do it in constant time.
However, because arrays are represented with continuous memory blocks, removing an arbitrary item (except for the last item) means we have to deal with "holes" in a data structure. The next picture illustrates it.

To get rid of holes, we have to shift all the items from the "hole" to the end of the array, one position closer to the beginning of the array. And in the worst case, if we remove the first item, we have to shift all the other items, and the time complexity of this operation will be O(N). In the best case, we will have O(1) time complexity when removing the last item.

def delete_element(arr, index):
   
    if index < 0 or index >= len(arr):
        print("Error: Index out of range.")
        return arr
    return np.delete(arr, index)

Insert operation

Like deleting elements, when inserting an item into an array, we may need to shift existing elements to make space for the new item. In the worst-case scenario, when inserting at the beginning of the array, we would need to shift the entire array, resulting in a time complexity of O(n). However, when inserting at the end of the array, we can simply place the new item without any shifting, resulting in a time complexity of O(1).

def insert_element(array, index, value):

    # Check if the index is valid
    if index < 0 or index > len(array):
        raise IndexError("Index is out of bounds.")

    # Insert the value at the specified index using numpy.insert
    new_array = np.insert(array, index, value)

    return new_array
question mark

What is the time complexity for inserting an item to the beginning and to the end of an array?

Select the correct answer

Was alles duidelijk?

Hoe kunnen we het verbeteren?

Bedankt voor je feedback!

Sectie 2. Hoofdstuk 2

Vraag AI

expand

Vraag AI

ChatGPT

Vraag wat u wilt of probeer een van de voorgestelde vragen om onze chat te starten.

Suggested prompts:

Stel mij vragen over dit onderwerp

Vat dit hoofdstuk samen

Toon voorbeelden uit de praktijk

Awesome!

Completion rate improved to 4.35

bookBasic Array Operations Time Complexity

Veeg om het menu te tonen

The next table shows the time complexity of basic operations for arrays.

Search operation

As we discussed previously and as it can be seen from the above, the main advantage of the array is that we can access an arbitrary item in constant time if we know the index of that item in an array. But if we don't know what item we are looking for, the lookup operation takes O(N) time complexity as we must provide a Linear Search for an element.

def search_array(arr, target):
    
    return np.any(arr == target)

Delete operation

If we want to delete an item by index, we can do it in constant time.
However, because arrays are represented with continuous memory blocks, removing an arbitrary item (except for the last item) means we have to deal with "holes" in a data structure. The next picture illustrates it.

To get rid of holes, we have to shift all the items from the "hole" to the end of the array, one position closer to the beginning of the array. And in the worst case, if we remove the first item, we have to shift all the other items, and the time complexity of this operation will be O(N). In the best case, we will have O(1) time complexity when removing the last item.

def delete_element(arr, index):
   
    if index < 0 or index >= len(arr):
        print("Error: Index out of range.")
        return arr
    return np.delete(arr, index)

Insert operation

Like deleting elements, when inserting an item into an array, we may need to shift existing elements to make space for the new item. In the worst-case scenario, when inserting at the beginning of the array, we would need to shift the entire array, resulting in a time complexity of O(n). However, when inserting at the end of the array, we can simply place the new item without any shifting, resulting in a time complexity of O(1).

def insert_element(array, index, value):

    # Check if the index is valid
    if index < 0 or index > len(array):
        raise IndexError("Index is out of bounds.")

    # Insert the value at the specified index using numpy.insert
    new_array = np.insert(array, index, value)

    return new_array
question mark

What is the time complexity for inserting an item to the beginning and to the end of an array?

Select the correct answer

Was alles duidelijk?

Hoe kunnen we het verbeteren?

Bedankt voor je feedback!

Sectie 2. Hoofdstuk 2
some-alt