Các thuật toán tìm đường đi trong mê cung là những phương
pháp được tự động hóa để giải một mê cung. Các thuật toán chọn đường ngẫu
nhiên, bám theo tường, Pledge, và Trémaux được xây dựng để một đối tượng sử dụng
chạy bên trong mê cung mà hoàn toàn không có biết trước về mê cung, còn các thuật
toán lấp kín đường cụt và đường đi ngắn nhất được thiết kế để sử dụng khi đã biết
trước toàn bộ mê cung.
Mê cung không chứa các vòng lặp được gọi là mê cung
"tiêu chuẩn" hoặc "hoàn hảo", và nó tương đương với một cây
trong lý thuyết đồ thị. Vì vậy, nhiều thuật toán tìm đường đi trong mê cung có
liên quan chặt chẽ với lý thuyết đồ thị. Một cách trực quan, nếu ta kéo dài các
đường trong mê cung ra một cách thích hợp, kết quả thu được có thể trông giống
như một cây.
1. Thuật toán chọn đường ngẫu nhiên
Đây là một phương pháp đơn giản có thể được thực hiện bởi một
robot rất không thông minh hoặc thậm chí là một con chuột (còn gọi là thuật
toán random mouse). Nó chỉ đơn giản là chạy theo một đường thẳng cho đến khi gặp
một đường giao nhau thì đưa ra quyết định ngẫu nhiên về hướng tiếp theo để chạy.
Mặc dù phương pháp này cuối cùng luôn luôn tìm ra giải pháp đúng, nhưng thuật
toán này có thể cực kỳ chậm.
2. Bám theo tường
Thuật toán bám theo tường (wall follower) là một quy tắc nổi
tiếng nhất để vượt qua mê cung, còn được gọi là quy tắc tay trái hoặc quy tắc
tay phải. Nếu mê cung chỉ liên thông đơn giản nghĩa là tất cả các bức tường của
nó được kết nối với nhau hoặc kết nối với đường bao quanh mê cung, thì bằng
cách dò một tay lên một bức tường của mê cung thì người đi đảm bảo không bị lạc
và tìm được lối ra nếu có một lối ra trên đường bao; hoặc nếu không có lối ra
thì sẽ quay trở lại lối vào và sẽ đi qua tất cả các đường của mê cung ít nhất 1
lần.
Đây là một khía cạnh khác cho thấy lý do vì sao việc bám
theo tường là một topo. Nếu các bức tường được kết nối, thì có thể được kéo
giãn biến dạng thành một vòng lặp hoặc vòng tròn. Do đó, bức tường buộc người
đi theo xung quanh một vòng tròn từ điểm đầu đến cuối.
3. Thuật toán Pledge
Ví dụ thuật toán giúp vượt qua vật cản hình chữ
"G": quay ngược kim đồng hồ là chiều dương, quay cùng chiều kim đồng
hồ là chiều âm. Các số liệu tương ứng với từng lần quay.
Hình 2: Thuật toán Pledge |
Giải thuật Pledge được thiết kế để vượt qua vật cản, bằng
cách chọn một hướng đi bất kỳ. Khi gặp vật cản, thì chuyển sang di chuyển bám
theo tường dọc theo vật cản, kết hợp với đếm góc quay. Sau khi bám tường và
quay mà trở về lại đúng hướng đi ban đầu đồng thời tổng góc đã quay bằng '0'
(zero) thì tức là đã vượt qua khỏi vật cản, thì không cần bám tường nữa và tiếp
tục di chuyển theo hướng ban đầu đã chọn.
Chỉ thoát khỏi bám theo tường khi thỏa mãn cả 2 điều kiện:
"hướng hiện tại trùng với hướng ban đầu" và "tổng số góc đã quay
bằng '0'". Điều này là cần thiết để giúp di chuyển vòng qua vật cản phức tạp
ví dụ như vật cản hình chữ "G" như trong hình. Ở vị trí +360o, robot
có hướng di chuyển cùng hướng ban đầu, nếu bỏ bám tường bên phải mà tiếp tục di
chuyển thẳng thì sẽ đi vào 1 vòng lặp mà không thoát ra được. Thay vào đó, nếu
tiếp tục bám vào tường phải và thực hiện quay cho đến khi tổng góc quay là '0'
thì sẽ thoát ra khỏi vật cản.
4. Thuật toán Trémaux
Thuật toán Trémaux được Charles Pierre Trémaux phát minh, sử
dụng các dấu hiệu để ghi nhớ đường đi, ví dụ đánh dấu trên mặt sàn, là một
phương pháp hiệu quả để tìm lối ra của một mê cung. Thuật toán có thể giải tất
cả các mê cung có đường đi rõ ràng.
Một đường trong mê cung sẽ được ghi nhớ bằng cách đánh dấu
bởi 1 trong 3 trạng thái: chưa qua, đã qua 1 lần hoặc qua 2 lần. Một đường được
chọn để đi sẽ luôn được đánh dấu bằng 1 vạch dưới sàn (từ ngã giao này đến ngã
giao kia). Tại điểm bắt đầu có thể chọn một hướng bất kỳ (nếu có nhiều hơn một
hướng). Khi đến một ngã giao, nếu các đường rẽ đều chưa qua, thì chọn ngẫu
nhiên 1 đường để đi và đánh dấu đường ấy 1 vạch. Khi gặp một ngã giao mà đường
trước mặt theo hướng đi hiện tại đã có 1 dấu, và đường đang đi hiện tại chỉ mới
đánh dấu 1 lần, thì quay trở lại và đánh dấu đường ấy 2 vạch. Nếu đến 1 ngã
giao mà không rơi vào 2 trường hợp trên, thì chọn đường đi có ít vạch nhất, và
nhớ đánh dấu đường ấy luôn. Khi đến đích, thì những con đường chỉ đánh dấu 1 vạch
là đường dẫn trở về điểm xuất phát.
Nếu không có ngã ra, thì phương pháp này sẽ dẫn người đi trở
về lại điểm xuất phát, và khi ấy tất cả con đường sẽ đánh dấu 2 vạch, mỗi vạch
tương ứng với 1 hướng đi. Kết quả được gọi là vạch đôi 2 chiều.
Về cơ bản, thuật toán này được phát hiện từ thế kỷ 19 đã được
sử dụng khoảng hàng trăm năm sau như một phương pháp tìm kiếm ưu tiên chiều
sâu.
5. Lấp kín đường cụt
Lấp kín đường cụt (dead-end filling) là một thuật toán để
giải mê cung bằng cách lấp kín tất cả các ngã cụt, chỉ để lại một đường chính
xác không bị lấp. Nó có thể được sử dụng để giải các mê cung trên giấy hoặc với
một chương trình máy tính, nhưng nó không hữu dụng nếu mê cung chưa biết bởi vì
phương pháp này phải biết trước toàn bộ bộ mê cung. Các bước của phương pháp lấp
kín đường cụt là:
Tìm tất cả điểm cụt trong mê cung, "Lấp kín" các con đường từ mỗi điểm cụt cho đến
ngã giao đầu tiên.