Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 26.09.2014
Сообщений: 17

DFS, TopologicalSort

20.09.2018, 16:50. Показов 855. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день,

Есть алгоритм обхода в глубину и есть простой граф и два вопроса:
1. Почему тут (https://www.cs.usfca.edu/~gall... n/DFS.html), вывод вершин в другом порядке?
2. И как переписать dfs для топологической сортировки.

Граф:
Python
1
2
3
4
5
6
7
8
9
10
g = {
    0: [[1, 1]],
    1: [[2, 1], [3, 1], [5, 1], [6, 1]],
    2: [[6, 1]],
    3: [[7, 1]],
    4: [[6, 1]],
    5: [],
    6: [[7, 1]],
    7: []
}
DFS:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
from collections import deque
 
def dfs(graph, start):
    color = dict().fromkeys(graph.keys(), 'White')
    color[start] = 'Grey'
    path = {start: start}
    order = list()
    stack = deque()
    stack.append(start)
    while stack:
        current = stack.pop()
        for edge, dist in graph[current]:
            if color[edge] == 'White':
                color[edge] = 'Grey'
                path[edge] = current
                stack.append(edge)
            color[current] = 'Black'
    return path.keys()
P.S. Вроде ссылки на сайте вставлять можно. Если нет, отпишитесь уберу.
P.P.S. Мне интересно именно с этим алгоритмом разобраться.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.09.2018, 16:50
Ответы с готовыми решениями:

DFS
Всем добрый вечер. Пишу рекурсивный дфс для нахождения пути в обыкновенном двунаправленном графе. Столкнулся с проблемой слишком глубокой...

Задача на графы (dfs,topsort)
Предприятие «Авто-2010» выпускает двигатели для известных во всём мире автомобилей. Двигатель состоит ровно из n деталей, пронумерованных...

Нерекурсивный DFS
Структура дерева: struct BinTree { int val; bool colour = false; //true - уже распечатали вершину BinTree *left=NULL; BinTree...

1
0 / 0 / 0
Регистрация: 26.09.2014
Сообщений: 17
21.09.2018, 16:39  [ТС]
Решение найдено, скидываю, может кому пригодиться.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
from collections import deque
 
 
def dfs(graph, start):
    color = dict().fromkeys(graph.keys(), 'White')
    color[start] = 'Grey'
    path = {start: start}
    stack = deque()
    stack.append(start)
    while stack:
        current = stack.pop()
        for edge, dist in graph[current]:
            if color[edge] == 'White':
                color[edge] = 'Grey'
                path[edge] = current
                stack.append(edge)
            color[current] = 'Black'
    return path.keys()
 
 
def topological_sort(graph):
    visited = list()
    for i in graph.keys():
        visited = visited + [j for j in dfs(graph, i) if j not in visited][::-1]
    return visited[::-1]
 
g1 = {
    0: [[4, 1]],
    1: [[5, 1], [2, 1]],
    2: [],
    3: [[5, 1]],
    4: [[7, 1]],
    5: [[7, 1]],
    6: [[7, 1]],
    7: []
}
 
g2 = {
    0: [[4, 1]],
    1: [[6, 1], [5, 1], [3, 1]],
    2: [[5, 1]],
    3: [[7, 1]],
    4: [[7, 1]],
    5: [],
    6: [[7, 1]],
    7: []
}
 
print(topological_sort(g1))  # [6, 3, 1, 5, 2, 0, 4, 7]
print(topological_sort(g2))  # [2, 1, 6, 5, 3, 0, 4, 7]
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.09.2018, 16:39
Помогаю со студенческими работами здесь

DFS Скачки
Скачки (Время: 1 сек. Память: 16 Мб Сложность: 32%) Иван Иванович любит ходить на скачки, надеясь на них заработать кругленькую сумму....

DFS тонкости
Всем привет! Интересует вопрос 1. Почему если копировать файл с 1 сервера на 2, затем подключить DFS ( Имеется ввиду репликация )...

DFS Algorithm
Дан граф G=(V,E),в котором V={v,s,w,q,t,x,y,z},E={(v,w),(w,s),(s,v),(q,w),(q,s),(q,t),(t,y),(y,q),(t,x)(x,z),(z,x)}.Надо провести алгоритм...

Репликация DFS
Добрый вечер! Задание выполняется на вирт. машинах. Есть домен sochi.wsr.ru. В нем два ПК: FS1 и FS2. На обоих серверах настроены...

не работает DFS
Решаю задачу с информатикса. http://informatics.mccme.ru/mod/statements/view.php?id=256#1 package ddf; import java.util.Scanner; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru