14/08/2018, 12:43

Giải thuật tìm kiếm theo chiều rộng

Giải thuật tìm kiếm theo chiều rộng là gì ? Giải thuật tìm kiếm theo chiều rộng (Breadth First Search – viết tắt là BFS) duyệt qua một đồ thị theo chiều rộng và sử dụng hàng đợi (queue) để ghi nhớ đỉnh liền kề để bắt đầu việc tìm kiếm khi không gặp được đỉnh liền kề trong bất kỳ vòng lặp ...

Giải thuật tìm kiếm theo chiều rộng là gì ?

Giải thuật tìm kiếm theo chiều rộng (Breadth First Search – viết tắt là BFS) duyệt qua một đồ thị theo chiều rộng và sử dụng hàng đợi (queue) để ghi nhớ đỉnh liền kề để bắt đầu việc tìm kiếm khi không gặp được đỉnh liền kề trong bất kỳ vòng lặp nào.

Giải thuật tìm kiếm theo chiều rộng

Như trong hình ví dụ trên, giải thuật tìm kiếm theo chiều rộng duyệt từ A tới B tới E tới F sau đó tới C, tới G và cuối cùng tới D. Giải thuật này tuân theo qui tắc:

Bảng dưới đây minh họa cách giải thuật tìm kiếm theo chiều rộng làm việc với một ví dụ đơn giản sau:

Bước Duyệt Miêu tả
1. Giải thuật tìm kiếm theo chiều rộng Khởi tạo hàng đợi (queue)
2. Giải thuật tìm kiếm theo chiều rộng Chúng ta bắt đầu duyệt đỉnh S (đỉnh bắt đầu) và đánh dấu đỉnh này là đã duyệt.
3. Giải thuật tìm kiếm theo chiều rộng Sau đó chúng ta tìm đỉnh liền kề với Smà chưa được duyệt. Trong ví dụ này chúng ta có 3 đỉnh, và theo thứ tự chữ cái chúng ta chọn đỉnh A đánh dấu là đã duyệt và xếp A vào hàng đợi.
4. Giải thuật tìm kiếm theo chiều rộng Tiếp tục duyệt đỉnh liền kề với SB. Đánh dấu là đã duyệt và xếp đỉnh này vào hàng đợi.
5. Giải thuật tìm kiếm theo chiều rộng Tiếp tục duyệt đỉnh liền kề với SC. Đánh dấu là đã duyệt và xếp đỉnh này vào hàng đợi.
6. Giải thuật tìm kiếm theo chiều rộng Bây giờ đỉnh S không còn đỉnh nào liền kề mà chưa được duyệt. Bây giờ chúng ta rút A từ hàng đợi.
7. Giải thuật tìm kiếm theo chiều rộng Từ đỉnh A chúng ta có đỉnh liền kề là D và là đỉnh chưa được duyệt. Đánh dấu đỉnh D là đã duyệt và xếp vào hàng đợi.

Đến đây, chúng ta thấy rằng không còn đỉnh nào là chưa được đánh dấu (chưa được duyệt với ví dụ trong bảng này). Nhưng giải thuật vẫn tiếp tục, chúng ta vẫn tiếp tục rút các đỉnh từ hàng đợi theo thứ tự để tìm tất cả các đỉnh mà chưa được duyệt. Khi hàng đợi là trống thì đó là lúc kết thúc giải thuật.

Trên đây là phần giới thiệu và minh họa cho giải thuật tìm kiếm theo chiều rộng với một đồ thị gồm 5 đỉnh. Để tìm hiểu code đầy đủ của giải thuật tìm kiếm theo chiều rộng trong ngôn ngữ C, mời bạn click chuột vào chương: Tìm kiếm theo chiều rộng trong C.

Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.

Bài học Cấu trúc dữ liệu và giải thuật phổ biến tại code24h.com:

0