logo
SEE ALGORITHMS
    Bubble Sort
    Insertion Sort
    Selection Sort
    Heap Sort
    Radix Sort
    Merge Sort
    Quick Sort

Breadth First Search

Breadth-First Search (BFS) explores a graph much like finding connections in a social network. Starting from a source node, it first visits all of its direct friends (neighbors), then all of their friends, and so on, level by level. It uses a queue to keep track of who to visit next, ensuring it doesn't go too deep down one path. This makes it perfect for finding the shortest path in an unweighted graph.

queue = new Queue()
queue.enq(src)
mark src as visited
while queue is not empty:
    u = queue.deq()
    for each neighbor v of u:
        if v is not visited:
            queue.enq(v)
            mark v as visited
Draw Graph

Curious to Learn More?

Hand-picked resources to deepen your understanding

Beginner Friendly
Grokking Algorithms

A friendly, fully illustrated guide. The best starting point for visual learners.

Practical Guide
A Common-Sense Guide to Data Structures and Algorithms

A practical guide with clear explanations and real-world examples.

Deep Dive
Introduction to Algorithms

The definitive guide (CLRS). Comprehensive and rigorous, perfect for deep diving into theory.

As an Amazon Associate, I earn from qualifying purchases. This helps support the site at no extra cost to you.

© 2025 SEE Algorithms. Code licensed under MIT, content under CC BY-NC 4.0.