Макеты страниц
6.3. Метод поиска в глубинуОдин из наиболее естественных способов систематического исследования всех вершин графа исходит из процедуры прохождения графа методом поиска с возвращением, который исследует граф в глубину (см. п. 4.1). На неориентированном графе другое ребро. Если вершина у не пройдена, то заходим в нее и применяем процесс прохождения рекурсивно уже с вершиной у. Если все ребра, инцидентные вершине Поиск в глубину можно также осуществлять и на ориентированном графе. Если граф ориентированный, то, находясь в узле х, необходимо выбирать ребро Метод поиска в глубину на простом неориентированном графе представлен в алгоритме 6.1. Рекурсивная процедура • Сложность поиска в глубину. Поскольку для каждой вершины, которую проходим впервые, выполняется обращение к процедуре Алгоритм 6.1. Поиск в глубину на простом неориентированном графе (см. скан) Программная реализация алгоритма 6.1 представлена алгоритмом 6.2. Реализация близко соответствует основному алгоритму 6.1. Программа представлена тремя процедурами представляется как Например, для следующей структуры смежности графа
соответствующие массивы в программной реализации принимают вид
Исходные данные для расчета по программе алгоритма 6.2 представляются в текстовом файле со следующей структурой смежности • в первой строке файла содержится количество строк в структуре смежности, которое равно числу вершин в графе; • далее для каждой вершины в отдельной строке указывается номер самой вершины, количество вершин, смежных с данной, и список этих вершин. Рассмотрим пример расчета по программе алгоритма 6.2 обхода графа, представленного на рис. 6.13. Сплошными линиями отмечены ребра, которые были пройдены во время обхода графа в глубину, пунктирными — обратные ребра.
Рис. 6.13. Пример обхода графа в глубину Исходные данные структуры смежности графа рис. 6.13 задаются в текстовом файле
Результаты расчетов сохраняются в выходном файле
Каждая колонка таблицы выходного файла соответствует Алгоритм 6.2. Программа поиска в глубину на простом неориентированном графе (см. скан) (см. скан) (см. скан)
|
1 |
Оглавление
|