Tìm kiếm theo chiều rộng
Phân loại | Thuật toán tìm kiếm |
---|---|
Cấu trúc dữ liệu | Đồ thị |
Hiệu suất trường hợp tệ nhất | |
Độ phức tạp không gian trường hợp tệ nhất | |
Tối ưu | tối ưu (cho đồ thị không trọng số) |
Trong lý thuyết đồ thị, tìm kiếm theo chiều rộng (BFS) là một thuật toán tìm kiếm trong đồ thị trong đó việc tìm kiếm chỉ bao gồm 2 thao tác: (a) cho trước một đỉnh của đồ thị; (b) thêm các đỉnh kề với đỉnh vừa cho vào danh sách có thể hướng tới tiếp theo. Có thể sử dụng thuật toán tìm kiếm theo chiều rộng cho hai mục đích: tìm kiếm đường đi từ một đỉnh gốc cho trước tới một đỉnh đích, và tìm kiếm đường đi từ đỉnh gốc tới tất cả các đỉnh khác. Trong đồ thị không có trọng số, thuật toán tìm kiếm theo chiều rộng luôn tìm ra đường đi ngắn nhất có thể. Thuật toán BFS bắt đầu từ đỉnh gốc và lần lượt nhìn các đỉnh kề với đỉnh gốc. Sau đó, với mỗi đỉnh trong số đó, thuật toán lại lần lượt nhìn trước các đỉnh kề với nó mà chưa được quan sát trước đó và lặp lại. Xem thêm thuật toán tìm kiếm theo chiều sâu, trong đó cũng sử dụng 2 thao tác trên nhưng có trình tự quan sát các đỉnh khác với thuật toán tìm kiếm theo chiều rộng.
Đây là một thuật toán trong trí tuệ nhân tạo. Cấu trúc dữ liệu được sử dụng là hàng đợi (queue).
Thuật toán
[sửa | sửa mã nguồn]Thuật toán sử dụng một cấu trúc dữ liệu hàng đợi để lưu trữ thông tin trung gian thu được trong quá trình tìm kiếm:
- Chèn đỉnh gốc vào hàng đợi (đang hướng tới)
- Lấy ra đỉnh đầu tiên trong hàng đợi và quan sát nó
- Nếu đỉnh này chính là đỉnh đích, dừng quá trình tìm kiếm và trả về kết quả.
- Nếu không phải thì chèn tất cả các đỉnh kề với đỉnh vừa thăm nhưng chưa được quan sát trước đó vào hàng đợi.
- Nếu hàng đợi là rỗng, thì tất cả các đỉnh có thể đến được đều đã được quan sát – dừng việc tìm kiếm và trả về "không thấy".
- Nếu hàng đợi không rỗng thì quay về bước 2.
Ghi chú: Nếu sử dụng một ngăn xếp thay vì hàng đợi thì thuật toán trở thành thuật toán tìm kiếm theo chiều sâu.
Các đặc tính của thuật toán
[sửa | sửa mã nguồn]Không gian
[sửa | sửa mã nguồn]Nếu V là tập hợp đỉnh của đồ thị và là số đỉnh thì không gian cần dùng của thuật toán là .
Thời gian
[sửa | sửa mã nguồn]Nếu V, và E là tập hợp các đỉnh và cung của đồ thị, thì thời gian thực thi của thuật toán là vì trong trường hợp xấu nhất, mỗi đỉnh và cung của đồ thị được thăm đúng một lần. Ghi chú: nằm trong khoảng từ đến , tùy theo số cung của đồ thị.
Thuật toán tìm kiếm cây và đồ thị |
---|
Danh sách |
Liên quan |
Ứng dụng
[sửa | sửa mã nguồn]Thuật toán tìm kiếm theo chiều rộng được dùng để giải nhiều bài toán trong lý thuyết đồ thị, chẳng hạn như:
- Tìm tất cả các đỉnh trong một thành phần liên thông
- Thuật toán Cheney cho việc dọn rác
- Tìm đường đi ngắn nhất giữa hai đỉnh u và v (với chiều dài đường đi tính bằng số cung)
- Kiểm tra xem một đồ thị có là đồ thị hai phía
- Thuật toán Cuthill–McKee
- Thuật toán Ford–Fulkerson để tìm luồng cực đại trong mạng
Tìm các thành phần liên thông
[sửa | sửa mã nguồn]Tập hợp các đỉnh đã được quan sát bởi thuật toán tìm kiếm theo chiều rộng chính là thành phần liên thông chứa đỉnh gốc.
Kiểm tra đồ thị hai phía
[sửa | sửa mã nguồn]Có thể dùng thuật toán tìm kiếm theo chiều rộng để kiểm tra xem một đồ thị có phải đồ thị hai phía hay không, bằng cách tìm kiếm từ một đỉnh bất kì và gán nhãn chẵn lẻ cho các đỉnh được quan sát. Nghĩa là, gán nhãn 0 cho đỉnh gốc, 1 cho tất cả các đỉnh kề đỉnh gốc, 0 cho tất cả các đỉnh kề với một đỉnh kề đỉnh gốc, và tiếp tục như vậy. Nếu ở một bước nào đó, có hai đỉnh kề nhau có cùng nhãn, thì đồ thị không là hai phía. Nếu quá trình tìm kiếm kết thúc mà điều này không xảy ra thì đồ thị là hai phía.
Xem thêm
[sửa | sửa mã nguồn]Tham khảo
[sửa | sửa mã nguồn]- Knuth, Donald E. (1997), The Art Of Computer Programming, 1 (ấn bản thứ 3), Boston: Addison-Wesley, ISBN 0-201-89683-4, Bản gốc lưu trữ ngày 4 tháng 9 năm 2008, truy cập ngày 9 tháng 9 năm 2012