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

Как вывести все пути из вершины в вершину в графе на Python

07.04.2022, 21:54. Показов 4128. Ответов 2

Студворк — интернет-сервис помощи студентам
Имеется модифицированный обход в ширину. Модифицирован он так, что ищет путь между двумя вершинами графа. Мне нужно сделать так, чтобы выводились все простые пути из вершины в вершину. По коду AdjList - список смежности. Код немного корявый, но только вкатываюсь в теорию графов. Пытался использовать рекурсию, но он выдает ошибку переполнения стека.
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
def AllWays(self, a, b):
    
    q = []
    q.append(a)
    visited = {}
    while len(q) != 0:
        x = q.pop(0)
        if x == b:
            break
        c = self.__AdjList[x].keys()
        for y in c:
            if y not in visited:
                q.append(y)
                visited[y] = x
    return visited
 
def Maxversh222(graph):
print('Введите вершину начала обхода')
a = input()
print('Введите вершину конца обхода')
b = input()
visited = graph.AllWays(a,b)
x = b
while x != a:
    x = visited[x]
    print(f'<--- {x} ', end='')
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.04.2022, 21:54
Ответы с готовыми решениями:

Найти все пути в графе от одной вершины в другую
Нуждаюсь в помощи. Пытаюсь на основе поиска в ширину(BFS) найти все пути от одной вершины в другую. Программа выводит часть путей. У меня...

Найти все пути от заданной вершины длиной n в графе
Здравствуйте, не получается реализовать программу на прологе: Найти все пути от заданной вершины длиной n в графе. Заранее спасибо

Все простые пути на графе, ведущие от одной вершины к другой
Напишите программу, на входе которой вводятся две его вершины. Программа должна распечатывать все простые пути, ведущие от одной вершины к...

2
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
08.04.2022, 06:39
Цитата Сообщение от Pupochek Посмотреть сообщение
Пытался использовать рекурсию, но он выдает ошибку переполнения стека
попробуй увеличить лимит.
Python
1
2
import sys
sys.setrecursionlimit(10000)
0
0 / 0 / 0
Регистрация: 03.05.2020
Сообщений: 5
08.04.2022, 19:54  [ТС]
Разобрался, как сделать, если кому-то вдруг понадобится, вот код:
Python
1
2
3
4
5
6
7
8
9
10
11
    def AllWays2(self, a, b, q, visited):
        if a == b:
            print(q)
            return
        for u in self.__AdjList[a]:
            if u not in visited:
                q.append(u)
                visited.add(u)
                self.AllWays2(u, b, q, visited)
                q.pop()
                visited.remove(u)
Вызов выглядит следующим образом:
Python
1
2
3
4
5
6
7
8
def Maxversh(graph):
    print('Введите вершину начала обхода')
    a = input()
    print('Введите вершину конца обхода')
    b = input()
    q = []
    visited = set()
    graph.AllWays2(a, b, q, visited)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.04.2022, 19:54
Помогаю со студенческими работами здесь

Найти на графе все пути длиной два, соединяющие вершины 1 и 2.
Ребят! Помогите срочно! Такой вопрос по графам: Дана матрица смежности A. По ней построен граф. Затем была построена матрица путей длины...

Написать программу с логической функцией paht(g,n,k,d), которая определяет, есть ли в ориетированном графе g путь из вершины n в вершину k
Написать программу с логической функцией paht(g,n,k,d), которая определяет, есть ли в ориетированном графе g путь из вершины n в вершину k,...

Графы, Вывести все кратчайшие пути из вершины u
Вот мой код, с помощью Дейкста, выводит минимальный ВЕС пути из вершины u в другие вершины! А мне надо, что бы он еще и выводил САМ...

В заданном графе найдите все вершины, растояние от которых до заданной вершины равно 2
гласит так: &quot;В заданном графе найдите все вершины, растояние от которых до заданной вершины равно 2.&quot;

Графы: заданы две вершины, начальная и конечная, требуется найти первую вершину в пути между ними
Задан граф матрицей смежности Заданы две вершины, начальная и конечная, требуется найти первую вершину в пути между ними


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru