DEV Community

Cover image for A Beginner's Guide to Data Structures in Python
Dedan Okware
Dedan Okware

Posted on

A Beginner's Guide to Data Structures in Python

Data Structures in Python

Data structures are a fundamental concept in computer science, as they allow us to organize and store data in a way that is efficient and easy to manipulate. Python has a number of built-in data types and collections that can be used as data structures, as well as classes that you can use to implement your own data structures. In this tutorial, we will discuss some of the common data structures and how to use them in Python.

Arrays

An array is a collection of items stored in contiguous memory locations. It is a simple data structure that allows for fast access to elements using their index. In Python, you can use the
list type to create an array-like structure.

Here's an example of how to create and manipulate an array using a list:

# Create an array with three elements
my_array = [1, 2, 3]

# Access an element by its index
print(my_array[0])  # Outputs 1

# Modify an element
my_array[0] = 4
print(my_array[0])  # Outputs 4

# Add an element to the end of the array
my_array.append(5)
print(my_array)  # Outputs [4, 2, 3, 5]

# Remove an element from the array
my_array.pop(1)
print(my_array)  # Outputs [4, 3, 5]

Enter fullscreen mode Exit fullscreen mode

Keep in mind that arrays have a fixed size, so if you need to add or remove elements, you may need to create a new array and copy over the elements.

Linked Lists

A linked list is a linear data structure where each element is a separate object that contains a value and a reference (pointer) to the next element. Linked lists can be used to implement stacks and queues, and they allow for fast insertion and deletion of elements. However, accessing a specific element in a linked list can be slower than in an array.

In Python, you can implement a linked list using the Nodeand LinkedListclasses shown below:

class Node:
    def __init__(self, value, next=None):
        self.value = value
        self.next = next

class LinkedList:
    def __init__(self, head=None):
        self.head = head

    def append(self, value):
        new_node = Node(value)
        if self.head is None:
            self.head = new_node
            return
        current = self.head
        while current.next is not None:
            current = current.next
        current.next = new_node

    def delete(self, value):
        current = self.head
        if current.value == value:
            self.head = current.next
            return
        while current.next is not None:
            if current.next.value == value:
                current.next = current.next.next
                return
            current = current.next

# Create a new linked list
linked_list = LinkedList()

# Append some elements
linked_list.append(1)
linked_list.append(2)
linked_list.append(3)

# Delete an element
linked_list.delete(2)

Enter fullscreen mode Exit fullscreen mode

Stacks

A stack is a linear data structure that follows the last-in, first-out (LIFO) principle. It has two main operations: push (add an element to the top of the stack) and pop (remove the element from the top of the stack). Stacks can be implemented using arrays or linked lists.

You can use a list as a stack by using its append and pop methods as shown in the array example above. Alternatively, you can implement a stack using the Stack class shown below:

class Stack:
    def __init__(self):
        self.items = []

    def push(self, item):
        self.items.append(item)

    def pop(self):
        return self.items.pop()

    def is_empty(self):
        return len(self.items) == 0

# Create a new stack
stack = Stack()

# Push some elements onto the stack
stack.push(1)
stack.push(2)
stack.push(3)

# Pop an element from the stack
print(stack.pop())  # Outputs 3
print(stack.pop())  # Outputs 2
print(stack.pop())  # Outputs 1
print(stack.is_empty())  # Outputs True
Enter fullscreen mode Exit fullscreen mode

Queues

A queue is a linear data structure that follows the first-in, first-out (FIFO) principle. It has two main operations: enqueue(add an element to the end of the queue) and dequeue(remove the element from the front of the queue). Queues can also be implemented using arrays or linked lists.

You can use the Queueclass from Python's queue module to implement a queue. Here's an example of how to use it:

from queue import Queue

# Create a new queue
queue = Queue()

# Enqueue some elements
queue.put(1)
queue.put(2)
queue.put(3)

# Dequeue an element
print(queue.get())  # Outputs 1
print(queue.get())  # Outputs 2

# Check if the queue is empty
print(queue.empty())  # Outputs False

Enter fullscreen mode Exit fullscreen mode

Trees

A tree is a hierarchical data structure with a root node and zero or more child nodes. Each child node can have its own child nodes, and so on. Trees can be used to represent hierarchical relationships, such as a file system.

You can implement a tree using the Nodeand Treeclasses shown below:

class Node:
    def __init__(self, value, children=None):
        self.value = value
        self.children = children or []

class Tree:
    def __init__(self, root):
        self.root = root

# Create a tree with a root node and three children
root = Node(1)
root.children = [Node(2), Node(3), Node(4)]
tree = Tree(root)

Enter fullscreen mode Exit fullscreen mode

Hash Tables

A hash table is a data structure that uses a hash function to map keys to indices in an array. It allows for fast insertion, deletion, and search operations, and it is often used to implement dictionaries and sets.

Python has a built-in dict type that implements a hash table. Here's an example of how to use it:

# Create a new hash table (dictionary)
hash_table = {}

# Add some key-value pairs
hash_table[1] = 'one'
hash_table['two'] = 2

# Access a value by its key
print(hash_table[1])  # Outputs 'one'

# Modify a value
hash_table['two'] = 'two'
print(hash_table['two'])  # Outputs 'two'

# Check if a key exists in the hash table
print(1 in hash_table)  # Outputs True
print(2 in hash_table)  # Outputs False

Enter fullscreen mode Exit fullscreen mode

Conclusion

In this tutorial, we learned about some of the common data structures and how to use them in Python. We covered arrays, linked lists, stacks, queues, trees, and hash tables. By understanding these data structures and how to use them effectively, you will be able to solve a wide variety of problems more efficiently and effectively.

I hope this tutorial was helpful! If you have any questions or need further clarification, please don't hesitate to ask.

Author: Dedan Okware
Email: softengdedan@gmail.com
LinkedIn: softcysec-dedan-okware

Top comments (0)