Графы. Поиск циклов. Определение предков в дереве

Содержание

Слайд 2

Определение

Предок (в наиболее используемом понимании), родитель – это вершина, из которой был

Определение Предок (в наиболее используемом понимании), родитель – это вершина, из которой
совершён переход в данную.
Предок вершины в дереве – любая вершина, расположенная на пути от данной до корня.
Наименьший общий предок двух вершин – это вершина максимально удалённая от корня дерева, которая является предком для обоих этих вершин.

Слайд 3

Алгоритм поиска циклов

Проведём поиск в глубину. Если граф ненаправленный, то дополнительно для

Алгоритм поиска циклов Проведём поиск в глубину. Если граф ненаправленный, то дополнительно
каждой вершины будем хранить родителя (номер вершины, из которой мы пришли в текущую), переход в родителя осуществлять не будем.
Если в какой-то момент обхода мы зашли в серую вершину, то мы нашли цикл.
С момента нахождения цикла будем добавлять текущую вершину в перечень вершин цикла и откатываться к предыдущей, пока не дойдём то старта цикла.

Слайд 4

Разница в нахождении цикла в направленном и ненаправленном графах

1

2

Нет цикла

1

2

Нет цикла

1

2

Есть цикл

Разница в нахождении цикла в направленном и ненаправленном графах 1 2 Нет

Слайд 5

Поиск циклов. Пример. Шаг 0

7

2

6

5

8

3

4

1

1

3

2

5

4

6

7

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 0 7 2 6 5 8 3 4

Слайд 6

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 1

7 2 6 5 8 3 4 1 1 3 2 6

Слайд 7

Поиск циклов. Пример. Шаг 2

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 2 7 2 6 5 8 3 4

Слайд 8

Поиск циклов. Пример. Шаг 3

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 3 7 2 6 5 8 3 4

Слайд 9

Поиск циклов. Пример. Шаг 4

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 4 7 2 6 5 8 3 4

Слайд 10

Поиск циклов. Пример. Шаг 5

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 5 7 2 6 5 8 3 4

Слайд 11

Поиск циклов. Пример. Шаг 6

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 6 7 2 6 5 8 3 4

Слайд 12

Поиск циклов. Пример. Шаг 7

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 7 7 2 6 5 8 3 4

Слайд 13

Поиск циклов. Пример. Шаг 8

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 8 7 2 6 5 8 3 4

Слайд 14

Поиск циклов. Пример. Шаг 9

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 9 7 2 6 5 8 3 4

Слайд 15

Поиск циклов. Пример. Шаг 10

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 10 7 2 6 5 8 3 4

Слайд 16

Поиск циклов. Пример. Шаг 11

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 11 7 2 6 5 8 3 4

Слайд 17

Поиск циклов. Пример. Шаг 12

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – нет Вершины в цикле:

Поиск циклов. Пример. Шаг 12 7 2 6 5 8 3 4

Слайд 18

Поиск циклов. Пример. Шаг 13

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – да Вершины в цикле: 4

Поиск циклов. Пример. Шаг 13 7 2 6 5 8 3 4

Слайд 19

Поиск циклов. Пример. Шаг 14

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – да Вершины в цикле: 4, 3

Поиск циклов. Пример. Шаг 14 7 2 6 5 8 3 4

Слайд 20

Поиск циклов. Пример. Шаг 15

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – да Вершины в цикле: 4, 3,

Поиск циклов. Пример. Шаг 15 7 2 6 5 8 3 4
8

Слайд 21

Поиск циклов. Пример. Шаг 16

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – да Вершины в цикле: 4, 3,

Поиск циклов. Пример. Шаг 16 7 2 6 5 8 3 4
8

Слайд 22

Поиск циклов. Пример. Шаг 17

7

2

6

5

8

3

4

1

1

3

2

6

7

5

4

Цикл найден – да Вершины в цикле: 4, 3,

Поиск циклов. Пример. Шаг 17 7 2 6 5 8 3 4
8

Слайд 23

Реализация

На рисунке представлен алгоритм нахождения цикла в ненаправленном графе.
В цикле в функции

Реализация На рисунке представлен алгоритм нахождения цикла в ненаправленном графе. В цикле
main вызов поиска осуществляется как dfs(i, -1), а не dfs(i).
Для направленного графа не нужно обрабатывать случай с предком.

Слайд 24

Алгоритм проверки является ли одна вершина предком для другой

Для каждой вершины будем

Алгоритм проверки является ли одна вершина предком для другой Для каждой вершины
дополнительно хранить время входа в неё (tin) и время выхода (tout).
Для этого заведём глобальный таймер. При входе в вершину запомним значение таймера в tin, и увеличим таймер на 1. Аналогично при выходе из вершины.
Вершина А является предком вершины В тогда и только тогда, когда A.tin ≤ B.tin и B.tout ≤ A.tout.
Стоит отметить, что при такой формулировке каждая вершина является своим же предком. Если такое явление нежелательно, то неравенства следует заменить на строгие.

Слайд 25

Предки в дереве

0

1

2

3

5

6

4

8

7

9

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

Предки в дереве 0 1 2 3 5 6 4 8 7

Слайд 26

Наивный алгоритм нахождения наименьшего общего предка вершин А и В

С помощью обхода

Наивный алгоритм нахождения наименьшего общего предка вершин А и В С помощью
в глубину, запущенного из корня, для каждой вершины посчитаем её время входа, время выхода и глубину (удалённость от корня).
В качестве результата на старте алгоритма возьмём корень дерева.
Переберём все вершины. Если вершина является предком для обеих вершин А и В, и она расположена глубже, чем текущая вершина, хранящаяся в результате, то данная вершина становится новым результатом.
Имя файла: Графы.-Поиск-циклов.-Определение-предков-в-дереве.pptx
Количество просмотров: 53
Количество скачиваний: 0