Лекция: Алгоритм поиска в ширину.
Алгоритм поиска в ширину работает следующим образом.
Дочерние состояния генерируются правилами вывода, допустимыми ходами игры, или другими операциями перехода состояний. На каждой итерации генерируются все дочерние вершины текущего состояния Х и записываются в open. Заметим, что список open действует как очередь и обрабатывает данные в порядке поступления (или «первым поступил — первым обслужен»). Это структура данных FIFO first-iп-firstout. Состояния добавляются в список справа, а удаляются слева. Таким образом в поиске участвуют состояния, которые находятся в списке open дольше всего, обеспечивая поиск в ширину. Дочерние состояния, которые были уже записаны в списки open или closed, отбрасываются. Алгоритм завершается, если текущее состояние буде равно целевому состоянию. Если алгоритм завершается из-за выполнения условия open= [пусто], то можно заключить, что весь граф исследован, а желаемая цель не достигнута. Следовательно, поиск потерпел неудачу.
Проследим путь алгоритма поиска в ширину breadth_first_search на графе, изображенном на рис. 10.10, при этом U — это желаемое целевое состояние.
0 итерация — Инициализируем списки. Список open =[A]; Списокclosed =[ ];
1 итерация – Выбираем первую вершину из списка openи определяем её как текущее состояние Х=А. Применяем процедуру определения потомков к Х=А, потомки есть, ими являются вершины В, С, D. Записываем справа налево эти вершины в список open,удаляя слева из этого списка вершину А и записывая эту вершину в списокclosed слева направо. Далее алгоритм переходит к следующей итерации.
2 итерация – Выбираем первую вершину из списка openи определяем её как текущее состояние Х=В. Применяем процедуру определения потомков к Х= В, потомки есть, ими являются вершины Е, F. Записываем справа налево эти вершины в список open,удаляя слева из этого списка вершину В и записывая эту вершину в списокclosed слева направо. Далее алгоритм переходит к следующей итерации.
Эти итерации продолжаются до тех пор пока текущее состояние Х не будет равно целевому состоянию U, либо список openокажется пустым.
Поскольку при поиске в ширину узлы графа рассматриваются по уровням, сначала исследуются те состояния, пути к которым короче. Поиск в ширину, таким образом, гарантирует нахождение кратчайшего пути от начального состояния к цели. Более того, поскольку вначале исследуются состояния, найденные по кратчайшему пути, при повторном проходе это состояние отбрасывается.
Иногда помимо имен состояний в ореn и closed необходимо хранить дополнительную информацию. Например, заметим, что алгоритм поиска в ширину не поддерживает список состояний на текущем пути к цели, как это делалось при поиске с возвратами (backtrack) в списке SL. Все посещенные состояния хранятся в closed. Если путь является решением, то он возвращается алгоритмом. Это может быть сделано путем накопления информации о предках для каждого состояния. Состояние хранится вместе с записью родительского состояния, Т.е. в виде пары (потомок- родитель).
После итерации | Список open | Списокclosed |
[А] | [ ] | |
[В СD ] | [А] | |
[С D Е F ] | [В А] | |
[D Е F G Н] | [С В А] | |
[Е F G Н I J] | [D С В А] | |
[F G Н I J K L] | [Е D С В А] | |
[G Н I J K L M] | [F Е D С В А] | |
[Н I J K L M N] | [G F Е D С В А] | |
[I J K L M N O P] | [Н G F Е D С В А] | |
[J K L M N O PQ] | [I Н G F Е D С В А] | |
[K L M N O PQ R] | [J I Н G F Е D С В А] | |
[L M N O PQ R S] | [K J I Н G F Е D С В А] | |
[M N O PQ R S T] | [L K J I Н G F Е D С В А] | |
[N O PQ R S T] | [M L K J I Н G F Е D С В А] | |
[O PQ R S T] | [N M L K J I Н G F Е D С В А] | |
[PQ R S T] | [O N M L K J I Н G F Е D С В А] | |
[Q R S TU ] | [P O N M L K J I Н G F Е D С В А] | |
[R S TU ] | [Q P O N M L K J I Н G F Е D С В А] | |
[S TU ] | [R Q P O N M L K J I Н G F Е D С В А] | |
[TU ] | [S R Q P O N M L K J I Н G F Е D С В А] | |
[U ] | [T S R Q P O N M L K J I Н G F Е D С В А] |
Таблица 10.2. Состояние списков после каждой итерации алгоритма поиска в ширину для графа на рис. 10.10.
После итерации | Список пар (потомок-родитель). |
(B,A), (C,A), (D,A) | |
(B,A), (C,A), (D,A), (E,B), (F,B) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E) | |
(B,A),(C,A),(D,A),(E,B),(F,B),(G,C),(H,C),(I,D),(J,D),(K,E),(L,E),(L,F), (M,F) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),( N, G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),(N,G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L),(U,P) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),(N,G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L),(U,P) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),(N,G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L),(U,P) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),(N,G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L),(U,P) | |
(B,A), (C,A), (D,A), (E,B), (F,B), (G,C), (H,C), (I,D),(J,D),(K,E), (L,E), (L,F), (M,F),(N,G),(O,H), (P,H),(P,I),(Q,I), (R,J),(S,K),(T,L),(U,P) |
Таблица 10.3. Состояние списка пар (потомок-родитель) после каждой итерации алгоритма поиска в ширину для графа на рис. 10.10.
Используя эту информацию, можно легко построить путь (А, В, F), ведущий от А к F. Когда цель найдена, можно создать алгоритм, который может восстановить путь решения, прослеживая его в обратном направлении от цели к начальному состоянию по родительским состояниям.