Breadth-First Search (BFS)
Breadth-First Search (BFS) və ya Genişlik-İlk Axtarış, qraf və ya ağac data strukturlarını gəzmək üçün istifadə olunan fundamental bir alqoritmdir. Bu alqoritm, başlanğıc node-dan eyni məsafədə olan bütün node-ları ziyarət etməyə üstünlük verir, sonra daha uzaq node-lara keçir.
BFS-in Əsas Xüsusiyyətləri
- Queue İstifadəsi: FIFO (First-In-First-Out) prinsipi ilə işləyən queue istifadə edir
- Səviyyə-Səviyyə Gəzinti: Qrafı və ya ağacı səviyyə-səviyyə gəzir
- Tam Gəzinti: Bütün node-ları ziyarət edir
- Genişlik Prioriteti: Dərinlik deyil, Genişlik prioritetləşdirilir
BFS-in İstifadə Sahələri
- Shortest Path: İki node arasında ən qısa yolun tapılması
- Connected Components: Qrafda əlaqəli komponentlərin tapılması
- Level Order Traversal: Ağacların səviyyə-səviyyə gəzintisi
- Network Broadcasting: Şəbəkə yayımı simulyasiyası
- Web Crawling: Veb səhifələrin indekslənməsi
BFS-in Java-da İmplementasiyası
koda bax
import java.util.*;
public class BFS {
    // Qraf təmsili (adjacency list)
    private Map<Integer, List<Integer>> graph;
    
    public BFS() {
        graph = new HashMap<>();
    }
    
    // Qrafa node əlavə etmək
    public void addNode(int node) {
        graph.putIfAbsent(node, new ArrayList<>());
    }
    
    // Qrafa kənar əlavə etmək
    public void addEdge(int source, int destination) {
        graph.putIfAbsent(source, new ArrayList<>());
        graph.get(source).add(destination);
    }
    
    // BFS alqoritmi
    public void bfs(int start) {
        Set<Integer> visited = new HashSet<>();
        Queue<Integer> queue = new LinkedList<>();
        
        // Başlanğıc node-u əlavə et
        visited.add(start);
        queue.add(start);
        
        while (!queue.isEmpty()) {
            // Queue-dan bir node çıxart
            int current = queue.poll();
            System.out.print(current + " ");
            
            // Bütün qonşuları gəz
            List<Integer> neighbors = graph.getOrDefault(current, Collections.emptyList());
            for (int neighbor : neighbors) {
                if (!visited.contains(neighbor)) {
                    visited.add(neighbor);
                    queue.add(neighbor);
                }
            }
        }
    }
    
    // Shortest path tapılması
    public int shortestPath(int start, int end) {
        if (start == end) {
            return 0;
        }
        
        Set<Integer> visited = new HashSet<>();
        Queue<Integer> queue = new LinkedList<>();
        Map<Integer, Integer> distance = new HashMap<>();
        
        visited.add(start);
        queue.add(start);
        distance.put(start, 0);
        
        while (!queue.isEmpty()) {
            int current = queue.poll();
            
            List<Integer> neighbors = graph.getOrDefault(current, Collections.emptyList());
            for (int neighbor : neighbors) {
                if (!visited.contains(neighbor)) {
                    visited.add(neighbor);
                    queue.add(neighbor);
                    distance.put(neighbor, distance.get(current) + 1);
                    
                    if (neighbor == end) {
                        return distance.get(neighbor);
                    }
                }
            }
        }
        
        return -1; // Yol tapılmadı
    }
    
    // Test
    public static void main(String[] args) {
        BFS bfs = new BFS();
        
        // Qraf yaratmaq
        for (int i = 0; i < 7; i++) {
            bfs.addNode(i);
        }
        
        bfs.addEdge(0, 1);
        bfs.addEdge(0, 2);
        bfs.addEdge(1, 3);
        bfs.addEdge(1, 4);
        bfs.addEdge(2, 5);
        bfs.addEdge(2, 6);
        
        System.out.println("BFS Traversal:");
        bfs.bfs(0);
        
        System.out.println("\nShortest path from 0 to 5: " + bfs.shortestPath(0, 5));
    }
}
Zaman və Yaddaş Mürəkkəbliyi
- Zaman Mürəkkəbliyi: O(V + E), burada V vertex-lərin sayı, E isə kənarların sayıdır
- Yaddaş Mürəkkəbliyi: O(V), ən pis halda bütün vertex-ləri queue-də saxlamalı ola bilərik