Data Structures in Python: A Complete Guide with Types and Examples

Data Structures in Python: A Complete Guide with Types and Examples

16 Dec 2024
Beginner
4.48K Views
53 min read
Learn with an interactive course and practical hands-on labs

Free DSA Online Course with Certification

Python Data Structures

Have you just started with Python? Python programming language can be used for anything. It's used for data analysis, scripting, software development, etc. Data structures are the building blocks of any programming language and so is Python. A data structure stores and organizes data in the computer's memory. It's a branch of computer science that deals with arranging large datasets in such a manner that they can be accessed and modified as per the requirements. 

In this Python tutorial, we'll delve into the different data structures in Python. If you're a beginner to Python, you must understand the data structures the language supports so we will also see Data structures in Python with examples for your strong understanding. So let's begin.

Read More: Top 50 Python Interview Questions and Answers

Types of Data Structures in Python

There are two main Types of data structures in Python lets see them one by one:

Types of Data Structures in Python

  1. Primitive Data Structures: They store the data of only one type. It is the basic way of representing data that contains simple values. Data types like integer, float, string, and booleans come in this category.
  2. Read More: Data Types in Python
  3. Non-Primitive Data Structures: They don't just store a value, but rather a collection of values in various formats. They can store data of more than one type.

    Non-primitive data structures can further be categorized into two categories:

    1. Built-In: Python offers implicit support for built-in structures that enable storing and accessing data e.g. lists, tuples, sets, and dictionaries.
    2. User-Defined: Python also provides the functionality to create your own data structures e.g. Stack, Tree, Queue, etc. so that you can have full control over their functionality.

Let's now study the Non-Primitive Data Structures in detail.

Built-In Data Structures in Python

1. Python Lists

Python Lists store data of different data types sequentially. It is a mutable data type in Python i.e. its elements can be changed after creation. We can access the elements of a list using indexes starting from 0. It's represented using square brackets [] and elements inside it are separated by commas.

Example: Python List Operations

        # Initializing a List
myList = ["ScholarHat", "Shailendra Chuauhan", "Girdhar Singh"]

# Display the list
print("A diverse Python list: ")
print(myList)

# Creating a Nested List
nestedList = [["Sakshi", "Sourav"], ["Pradnya", "Pragati"]]
print("\nNested List: ")
print(nestedList)

# Accessing elements from the list
print("\nAccessing elements from the list:")
print(myList[0])
print(myList[2])

# Accessing elements using negative indexing
print("\nAccessing elements with negative indexing:")

# Print the last element of the list
print(myList[-1])

# Print the second last element of the list
print(myList[-2])

The above program demonstrates the list and operations performed on it.

Output

A diverse Python list: 
['ScholarHat', 'Shailendra Chuauhan', 'Girdhar Singh']

Nested List: 
[['Sakshi', 'Sourav'], ['Pradnya', 'Pragati']]

Accessing elements from the list:
ScholarHat
Girdhar Singh

Accessing elements with negative indexing:
Girdhar Singh
Shailendra Chuauhan

2. Python Dictionary

A dictionary in Python is a group of key-value pairs. Every key is distinct and corresponds to a single value. It can be created using curly braces {} with key-value pairs separated by colons.

Python Dictionary

Example: Python Dictionary Operations

        # Creating a Dictionary with mixed keys
myDict = {'Course': 'Python', 34: ['Beginner', 'Advanced']}
print("Created Dictionary: ")
print(myDict)

# Accessing an element using its key
print("Accessing an element using its key:")
print(myDict['Course'])

# Accessing an element using the get() method
print("Accessing an element using get():")
print(myDict.get(34))

# Creating a dictionary using dictionary comprehension
squaredDict = {x: x**2 for x in range(1, 6)}
print("Dictionary comprehension example:")
print(squaredDict)

The above program demonstrates a dictionary and operations performed on it.

Output

Created Dictionary: 
{'Course': 'Python', 34: ['Beginner', 'Advanced']}
Accessing an element using its key:
Python
Accessing an element using get():
['Beginner', 'Advanced']
Dictionary comprehension example:
{1: 1, 2: 4, 3: 9, 4: 16, 5: 25}

3. Python Tuples

Tuples in Python are ordered collections of elements, similar to Python lists, but they are immutable. This implies that once a tuple has been created, it cannot be altered. Tuples can be formed by listing a sequence of values separated by commas, with or without enclosing parentheses.

Python Tuples

Example of a Tuple in Python

        # Defining a Tuple with string elements
myTuple = ('Welcome', 'to', 'ScholarHat')
print("\nTuple with strings:")
print(myTuple)
     
# Converting a list to a Tuple
myList = [100, 200, 300, 400]
print("\nTuple created from a list:")
myTuple = tuple(myList)

# Accessing elements through indexing
print("Accessing the first element of the tuple:")
print(myTuple[0])
 
# Using negative indexing to access elements
print("\nAccessing the last element of the tuple using negative indexing:")
print(myTuple[-1])
  

The above program demonstrates a tuple and operations performed on it.

Output

print("\nAccessing the third last element of the tuple:")
print(myTuple[-3])  

4. Python Sets

Sets in Python are an unordered collection of unique elements. These are enclosed in curly braces and are useful to create lists that only hold unique values in the dataset.

Python Sets

Example of a Set in Python

        # Creating a Set of both string and numerical values 
mySet = set([90, 'ScholarHat', 3.14, 'Shailendra Chauhan', 400, 'Sakshi'])
print("\nA Set with mixed value types:")
print(mySet)

# Iterating through the set using a for loop
print("\nIterating through the elements of the set:")
for item in mySet:
    print(item, end=" ")
print()

# Membership testing using the 'in' keyword
print("'ScholarHat' present in the set:", 'ScholarHat' in mySet)
  

The above program demonstrates a set and operations performed on it.

Output

A Set with mixed value types:
{3.14, 'ScholarHat', 400, 'Shailendra Chauhan', 'Sakshi', 90}

Iterating through the elements of the set:
3.14 ScholarHat 400 Shailendra Chauhan Sakshi 90 
'ScholarHat' present in the set: True

Python Frozen Sets

The frozenset class in Python implements an immutable version of the set that can’t be changed after it’s been constructed. The frozenset objects are static and allow only query operations on their elements, not insertions or deletions. As these objects are static and hashable, they can be used as dictionary keys or as elements of another set, which isn’t possible with regular set objects. To instantiate a frozen set, you need to provide an iterable as an argument to the frozen set () constructor.

Example of a Frozen Set in Python

        # Creating a regular set
regular_set = set(["Sakshi", "Pragati", "Shobha"])

print("Regular Set:")
print(regular_set)

# Creating a frozenset
immutable_set = frozenset(["Sourav", "Shailendra", "Girdhar"])

print("\nFrozen Set:")
print(immutable_set)

The above program differentiates between regular and frozen sets. While you can freely modify a regular set, attempting to alter a frozenset, such as adding new elements, will result in an error, underscoring the immutable nature of frozensets.

Output

Regular Set:
{'Shobha', 'Sakshi', 'Pragati'}

Frozen Set:
frozenset({'Girdhar', 'Sourav', 'Shailendra'})  

5. Python Bytearray

Python Bytearray gives a mutable sequence of integers in the range 0 <= x < 256. Unlike strings or tuples, bytearrays can be modified in place.

Example of a Bytearray in Python

        # Initializing a bytearray
byte_seq = bytearray([50, 100, 150, 200])
print("Initial Bytearray:")
print(byte_seq)

# Accessing elements in bytearray
print("\nAccessing an Element:", byte_seq[3])

# Modifying elements in the bytearray
byte_seq[1] = 190
print("\nAfter Modification:")
print(byte_seq)

# Appending new elements to the bytearray
byte_seq.append(205)
print("\nAfter Appending an Element:")
print(byte_seq)

The above program demonstrates a bytearray and operations performed on it.

Output

Initial Bytearray:
bytearray(b'2d\x96\xc8')

Accessing an Element: 200

After Modification:
bytearray(b'2\xbe\x96\xc8')

After Appending an Element:
bytearray(b'2\xbe\x96\xc8\xcd')

Collections Module in Python

Collection Module is a built-in module that provides alternatives to Python's general-purpose built-in containers, like dict, list, set, and tuple. It encompasses a range of specialized container data types, providing diverse alternatives to Python's native containers.

Read More: Modules in Python

Let's look at some of the most commonly used containers within the collection module.

1. Counters

Counters are a subclass of dictionaries designed to count hashable objects. Counters are invaluable for tallying elements and implementing counting algorithms with precision and efficiency.

Example of Counters in Python

        from collections import Counter

# Creating a counter
company = Counter(['ScholarHat', 'DotNetTricks', 'Sakshi', 'ScholarHat', 'DotNetTricks', 'Sakshi', 'ScholarHat'])
print("Company Counter:")
print(company)

# Updating the counter
company.update(['Sakshi', 'ScholarHat'])
print("\nAfter Updating:")
print(company)

# Accessing the most common elements
print("\nMost Common Elements:")
print(company.most_common(2))

The above program demonstrates a counter and its associated operations.

Output

Company Counter:
Counter({'ScholarHat': 3, 'DotNetTricks': 2, 'Sakshi': 2})

After Updating:
Counter({'ScholarHat': 4, 'Sakshi': 3, 'DotNetTricks': 2})

Most Common Elements:
[('ScholarHat', 4), ('Sakshi', 3)]

2. OrderedDict

An OrderedDict, a subclass of a dictionary, preserves the order of items as they're added, simplifying the insertion and deletion of elements.

Example of OrderedDict in Python

        from collections import OrderedDict

# Creating an OrderedDict
ordered_dict = OrderedDict([('ScholarHat', 2), ('DotNetTricks', 3), ('Sakshi', 1)])
print("OrderedDict:")
print(ordered_dict)

# Adding an element
ordered_dict.update({'Sourav': 4})
print("\nAfter Adding an Element:")
print(ordered_dict)

# Reversing the order
reverse_ordered_dict = OrderedDict(reversed(list(ordered_dict.items())))
print("\nReversed OrderedDict:")
print(reverse_ordered_dict)

The above program demonstrates the OrderedDict and its associated operations.

Output

OrderedDict:
OrderedDict([('ScholarHat', 2), ('DotNetTricks', 3), ('Sakshi', 1)])

After Adding an Element:
OrderedDict([('ScholarHat', 2), ('DotNetTricks', 3), ('Sakshi', 1), ('Sourav', 4)])

Reversed OrderedDict:
OrderedDict([('Sourav', 4), ('Sakshi', 1), ('DotNetTricks', 3), ('ScholarHat', 2)])

3. DefaultDict

It is a dictionary subclass that calls a factory function to supply missing values, simplifying the handling of missing keys.

Example of OrderedDict in Python

        from collections import defaultdict

# Creating a defaultdict
default_dict = defaultdict(int)
default_dict['ScholarHat'] = 1
default_dict['DotNetTricks'] += 3

print("DefaultDict:")
print(default_dict)

The above program demonstrates the creation of the DefaultDict.

Output

DefaultDict:
defaultdict(, {'ScholarHat': 1, 'DotNetTricks': 3})

4. ChainMap

A ChainMap groups multiple dictionaries into a single view, making it easy to manage multiple scopes.

Example of OrderedDict in Python

        from collections import ChainMap

dict1 = {'ScholaHat': 3, 'Sakshi': 2}
dict2 = {'Sourav': 4, 'ScholaHat': 1}

chain_map = ChainMap(dict1, dict2)
print("ChainMap:")
print(chain_map)

The above program demonstrates the creation of the ChainMap.

Output

ChainMap:
ChainMap({'ScholaHat': 3, 'Sakshi': 2}, {'Sourav': 4, 'ScholaHat': 1})

5. NamedTuple

NamedTuples facilitate the creation of tuple-like objects that support indexing, iteration, and accessing fields using attribute lookup.

Example of NamedTuple in Python

        from collections import namedtuple

# Creating a namedtuple
Employee = namedtuple('Employee', ['name', 'id'])
sakshi = Employee(name='Sakshi', id=5)

print("NamedTuple:")
print(sakshi.name, sakshi.id)

The above program demonstrates the creation of a NamedTuple.

Output

NamedTuple:
Sakshi 5

6. UserDict

UserDict is a wrapper around dictionary objects for easier dictionary subclassing.

Example of UserDict in Python

        from collections import UserDict

# Creating a UserDict
user_dict = UserDict(ScholarHat=2, DotNetTricks=3)
print("UserDict:")
print(user_dict)

The above program demonstrates the creation of a UserDict.

Output

UserDict:
{'ScholarHat': 2, 'DotNetTricks': 3}

7. UserString

UserString is a wrapper around string objects for easier string subclassing.

Example of UserDict in Python

        from collections import UserString

# Creating a UserString
user_string = UserString("Welcome to ScholarHat!")
print("UserString:")
print(user_string)

The above program demonstrates the creation of a UserString.

Output

UserString:
Welcome to ScholarHat!

User-Defined Data Structures in Python

1. Linked Lists

A Linked List is a linear data structure consisting of a series of connected nodes randomly stored in the memory. Here, each node consists of two parts, the first part is the data and the second part contains the pointer to the address of the next node.

Representation of Linked Lists

The first node of a linked list is called the Head, and it acts as an access point. The head pointer points to the first element of the linked list. The last node is called the Tail, and it marks the end of a linked list by pointing to a NULL value.

Example of a Linked List in Python

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

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

    def printList(self):
        temp = self.head
        while temp:
            print(temp.data)
            temp = temp.next

# Example usage
llist = LinkedList()
llist.head = Node(10)
second = Node(20)
third = Node(30)

llist.head.next = second
second.next = third

llist.printList()

The above program demonstrates the creation of a Linked List and its associated operations.

Output

10
20
30
Read More: Linked List in Data Structures

2. Stacks

A stack is an ordered list or a container where insertion and deletion can be done from one end known as the top of the stack. The last inserted element is available first and is the first one to be deleted. Hence, it is known as Last In, First Out LIFO, or First In, Last Out FILO.

Stacks

Stacks are dynamic; this means that they do not have a fixed size and their size can be increased or decreased depending on the number of elements.

Example of a Stack in Python

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

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

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

    def peek(self):
        return self.items[-1]

    def is_empty(self):
        return self.items == []

# Example usage
stack = Stack()
stack.push('ScholarHat')
stack.push('DotNetTricks')
print(stack.pop())

The above program demonstrates the creation of a Stack and its associated operations.

Output

DotNetTricks
Read More: Implementing Stack in Data Structures

3. Queue

A queue is an ordered list in which insertion is done at one end called REAR and deletion at another end called FRONT. The first inserted element is available first for the operations to be performed and is the first one to be deleted. Hence, it is known as First In First Out, FIFO, or Last In Last Out, LILO.

Queue in Data Structures

Queues can be implemented in Python using several methods:

1. Using a list

In this implementation method, the append() method is used for enqueue operations, while the pop(0) method is employed for dequeue operations.

Example of a Queue in Python

        # Initialize a queue
queue = []

# Enqueue operations
queue.append('Sakshi')
queue.append('Sourav')
queue.append('Pragati')

print("Initial queue:")
print(queue)

# Dequeue operations
print("\nItems removed from the queue:")
print(queue.pop(0))
print(queue.pop(0))
print(queue.pop(0))

print("\nQueue after dequeue operations:")
print(queue)
Using collections.deque
Using queue.Queue

The above program demonstrates the creation of a queue using a list and its associated operations.

Output

Initial queue:
['Sakshi', 'Sourav', 'Pragati']

Items removed from the queue:
Sakshi
Sourav
Pragati

Queue after dequeue operations:
[]

2. Using collections.deque

The collections.deque implementation has O(1) time complexity for append and pop operations from both ends, compared to the list's O(n) for certain operations.

Example of a Queue in Python

        from collections import deque

# Initialize a queue
queue = deque()

# Enqueue operations
queue.append('Sakshi')
queue.append('Sourav')
queue.append('Pragati')

print("Initial queue:")
print(queue)

# Dequeue operations
print("\nItems removed from the queue:")
print(queue.popleft())
print(queue.popleft())
print(queue.popleft())

print("\nQueue after dequeue operations:")
print(queue)

The above program demonstrates the creation of a queue using collections.deque and its associated operations.

Output

Initial queue:
deque(['Sakshi', 'Sourav', 'Pragati'])

Items removed from the queue:
Sakshi
Sourav
Pragati

Queue after dequeue operations:
deque([])

3. Using queue.Queue

The queue.Queue class provides a FIFO queue implementation suitable for multi-threading environments, with methods to check if the queue is full or empty.

Example of a Queue in Python

        from queue import Queue

# Initialize a queue with a specific max size
queue = Queue(maxsize=3)

# Check queue size
print(queue.qsize())

# Enqueue operations
queue.put('Sakshi')
queue.put('Sourav')
queue.put('Pragati')

# Check if the queue is full
print("\nIs the queue full?:", queue.full())

# Dequeue operations
print("\nItems removed from the queue:")
print(queue.get())
print(queue.get())
print(queue.get())

# Check if the queue is empty
print("\nIs the queue empty?:", queue.empty())

The above program demonstrates the creation of a queue using queue.Queue and its associated operations.

Output

0

Is the queue full?: True

Items removed from the queue:
Sakshi
Sourav
Pragati

Is the queue empty?: True
Read More: Queue in Data Structures

Priority Queue

It is a special type of queue in which each element has a priority assigned to it. The element with the highest priority is removed first.

Priority Queue in Data Structure Example

Example of a Queue in Python

        class SimplePriorityQueue:
    def __init__(self):
        self.queue = []

    def __str__(self):
        return ' '.join([str(i) for i in self.queue])

    # check if the queue is empty
    def isEmpty(self):
        return len(self.queue) == 0  # Corrected condition

    # add an element to the queue
    def insert(self, item):
        self.queue.append(item)

    # Method to remove an element based on priority
    def delete(self):
        try:
            if not self.isEmpty():  # Check if queue is empty
                highest_priority = 0
                for i in range(1, len(self.queue)):  # Start from index 1
                    if self.queue[i] > self.queue[highest_priority]:
                        highest_priority = i
                item = self.queue[highest_priority]
                del self.queue[highest_priority]
                return item
            else:
                raise IndexError("The queue is empty.")  # Raise IndexError if queue is empty
        except IndexError as e:
            print(e)
            return None

# Example usage
if __name__ == '__main__':
    priorityQueue = SimplePriorityQueue()
    priorityQueue.insert(40)
    priorityQueue.insert(20)
    priorityQueue.insert(50)
    priorityQueue.insert(10)
    print(priorityQueue)  # Displays the queue
    while not priorityQueue.isEmpty():
        print(priorityQueue.delete())  # Removes elements based on priority

The above program demonstrates the creation of a priority queue and its associated operations.

Output

40 20 50 10
50
40
20
10
Read More: Priority Queue in Data Structures

4. Tree

A tree is a collection of objects or entities known as nodes connected by edges and has a hierarchical relationship between the nodes.

The topmost node of the tree is called the root node from which the tree originates, and the nodes below it are called the child nodes. Each node can have multiple child nodes, and these child nodes can also have their child nodes, forming a recursive structure.

Example of a Tree in Python

        class Tree:
    def __init__(self, info, left=None, right=None):
        self.info = info
        self.left  = left
        self.right = right

    def __str__(self):
        return (str(self.info) + ', Left child: ' + str(self.left) + ', Right child: ' + str(self.right))

tree = Tree(1, Tree(2, 2.1, 2.2), Tree(3, 3.1))
print(tree)

The above program demonstrates the creation of a tree in python.

Output

1, Left child: 2, Left child: 2.1, Right child: 2.2, Right child: 3, Left child: 3.1, Right child: None
Read More: Trees in Data Structures - Its Structure, Operations & Applications

Heap

heapq module in Python provides the heap data structure which is a specialized data structure using Python that follows the heap queue or priority queue algorithm.

A heap is a tree-like data structure in which the tree is a complete binary tree that satisfies the heap property. According to the heap property, all the children of a given node must be greater than the parent node, or all the children must be smaller than the parent node. This type of data structure is also called a binary heap.

Max Heap

Min Heap

Example of a Heap in Python

        # Importing the heapq module for heap operations
import heapq

# Initializing a list
my_heap = [50, 20, 3, 70, 6, 8]

# Transforming the list into a heap
heapq.heapify(my_heap)

# Displaying the heap
print("Initial heap:", my_heap)

# Adding an element to the heap
heapq.heappush(my_heap, 4)

# Displaying the modified heap
print("Heap after adding an element:", my_heap)

# Removing and returning the smallest element from the heap
smallest_element = heapq.heappop(my_heap)

# Displaying the removed element
print("Smallest element removed from the heap:", smallest_element)

The above program demonstrates the creation of a heap in python.

Output

Initial heap: [3, 6, 8, 70, 20, 50]
Heap after adding an element: [3, 6, 4, 70, 20, 50, 8]
Smallest element removed from the heap: 3
Read More: Heap in Data Structures

5. Graph

A graph is a collection of nodes that consist of data and are connected to other nodes of the graph. formally a Graph is composed of a set of vertices( V ) and a set of edges( E ). The graph is denoted by G(V, E).

Finite Graph

Graphs can be represented in Python using two primary methods:

1. Adjacency Matrix

An Adjacency Matrix is a 2D array of size V x V where V is the number of nodes in a graph. It is used to represent a finite graph, with 0's and 1's. Since it's a V x V matrix, it is known as a square matrix. The elements of the matrix indicate whether pairs of vertices are adjacent or not in the graph i.e. if there is any edge connecting a pair of nodes in the graph.

Example of a Graph in Python

        class GraphMatrix:
    def __init__(self, numVertices):
        self.adjMatrix = [[0] * numVertices for _ in range(numVertices)]
        self.numVertices = numVertices

    def add_edge(self, start, end, weight=1):
        self.adjMatrix[start][end] = weight
        # For undirected graph, add an edge back
        self.adjMatrix[end][start] = weight

    def display(self):
        print("Adjacency Matrix:")
        for row in self.adjMatrix:
            print(row)

# Initialize the graph with 5 vertices
graphMatrix = GraphMatrix(5)

# Add edges
edges = [(0, 1), (0, 4), (1, 2), (1, 3), (1, 4), (2, 3), (3, 4)]
for start, end in edges:
    graphMatrix.add_edge(start, end)

# Display the adjacency matrix
graphMatrix.display()

The above program demonstrates the creation of a graph in python.

Output

Adjacency Matrix:
[0, 1, 0, 0, 1]
[1, 0, 1, 1, 1]
[0, 1, 0, 1, 0]
[0, 1, 1, 0, 1]
[1, 1, 0, 1, 0]

2. Adjacency List

An adjacency list represents a graph as an array of linked lists. The index of the array represents a vertex and each element in its linked list represents the other vertices that form an edge with the vertex.

Example of a Graph in Python

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

class GraphList:
    def __init__(self, vertices):
        self.V = vertices
        self.graph = [None] * self.V

    def add_edge(self, src, dest):
        # Add an edge from src to dest
        node = AdjNode(dest)
        node.next = self.graph[src]
        self.graph[src] = node

        # Since the graph is undirected, add an edge from dest to src
        node = AdjNode(src)
        node.next = self.graph[dest]
        self.graph[dest] = node

    def print_graph(self):
        for i in range(self.V):
            print(f"Adjacency list of vertex {i}", end="")
            temp = self.graph[i]
            while temp:
                print(f" -> {temp.vertex}", end="")
                temp = temp.next
            print(" \n")

# Initialize the graph with 5 vertices
graphList = GraphList(5)

# Add edges
edges = [(0, 1), (0, 4), (1, 2), (1, 3), (1, 4), (2, 3), (3, 4)]
for start, end in edges:
    graphList.add_edge(start, end)

# Print the adjacency list
graphList.print_graph()

The above program demonstrates the creation of a graph in python.

Output

Adjacency list of vertex 0 -> 4 -> 1 

Adjacency list of vertex 1 -> 4 -> 3 -> 2 -> 0 

Adjacency list of vertex 2 -> 3 -> 1 

Adjacency list of vertex 3 -> 4 -> 2 -> 1 

Adjacency list of vertex 4 -> 3 -> 1 -> 0
Read More: Graphs in Data Structures - Types of Graphs, Representation & Operations

6. HashMaps

HashMaps are like dictionaries in Python. They store key-value pairs. HashMaps uses a hash function to compute an index for each key, which leads to efficient retrieval and insertion.

Example of a HashMap in Python

        class HashMap:
    def __init__(self, size):
        self.size = size
        self.map = [None] * size

    def _hash(self, key):
        return hash(key) % self.size

    def add(self, key, value):
        index = self._hash(key)
        if self.map[index] is None:
            self.map[index] = []
        self.map[index].append((key, value))

    def get(self, key):
        index = self._hash(key)
        if self.map[index] is not None:
            for pair in self.map[index]:
                if pair[0] == key:
                    return pair[1]
        return None

    def remove(self, key):
        index = self._hash(key)
        if self.map[index] is not None:
            for i, pair in enumerate(self.map[index]):
                if pair[0] == key:
                    del self.map[index][i]
                    return

# Example usage:
if __name__ == "__main__":
    my_map = HashMap(10)
    my_map.add("apple", 10)
    my_map.add("banana", 20)
    my_map.add("orange", 30)

    print(my_map.get("apple"))  
    print(my_map.get("banana"))  
    print(my_map.get("orange"))  

    my_map.remove("banana")
    print(my_map.get("banana"))  

The above program demonstrates the creation of a HashMap in python.

Output

10
20
30
None
Read More: Hashing in Data Structures
Summary

Hence, in the above article, we saw all the prominent data structures in Python. Python's native data structures, including lists, dictionaries, tuples, and sets, offer a robust basis for storing and managing data in various ways. The user-defined data structures, such as stacks, arrays, queues, etc., reveal numerous avenues for creative problem-solving endeavors.

FAQs

Python data structures are collections of data elements organized and stored for efficient access and manipulation, including lists, tuples, dictionaries, sets, and arrays.

In Python, a set is a collection of unique elements without any particular order. It is defined by enclosing comma-separated values within curly braces {}.

DSA stands for Data Structures and Algorithms. It is a fundamental concept in computer science that involves the study of organizing, managing, and manipulating data efficiently, along with the design and analysis of algorithms to solve computational problems.

Python is good for DSA due to its rich set of built-in data structures (like lists, dictionaries, and sets) and extensive standard libraries, simplifying the implementation and experimentation of various algorithms, making it an ideal choice for learning and practicing DSA concepts.
Share Article
About Author
Sakshi Dhameja (Author and Mentor)

She is passionate about different technologies like JavaScript, React, HTML, CSS, Node.js etc. and likes to share knowledge with the developer community. She holds strong learning skills in keeping herself updated with the changing technologies in her area as well as other technologies like Core Java, Python and Cloud.

Accept cookies & close this