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

Алгоритм Прима

21.11.2019, 11:12. Показов 15112. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Просто организовать алгоритм Прима. Я не понимаю, как его сделать. Буду благодарен
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.11.2019, 11:12
Ответы с готовыми решениями:

Алгоритм Прима: построение min остовного дерева взвешенного связного неориентированного графа (Си -> Python)
задача: Алгоритм Прима. Алгоритм Прима — алгоритм построения минимального остовного дерева взвешенного связного неориентированного графа....

Метод Прима (нахождение минимального остова дерева), нужно найти ошибку
Ребят, нужна ваша помощь! Нужно реализовать метод Прима (нахождение минимального остова дерева). Дерево забил в виде смежной матрицы. Прошу...

Алгоритм Прима выдает ошибку нужно сделать ввод данных с консоли
import math def get_min(R, U): rm = (math.inf, -1, -1) for v in U: rr = min(R, key=lambda x: x if (x == v or x...

9
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
21.11.2019, 11:16
disconect, гугл отключили?

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
matr = [
         [0, -1, 15, 20, 15], 
         [-1, 0, 60, 50, 80], 
         [15, 60, 0, 50, 10], 
         [20, 50, 50, 0, 30], 
         [15, 80, 10, 30, 0]
       ]
 
Вот наши функции:
def search_min(tr, vizited):#1 место для оптимизации
    min=max(tr)
    for ind in vizited:
        for index, elem in enumerate(tr[ind]):
            if elem>0 and elem<min and index not in vizited:
                min=elem#веса путей
                index2=index# индекс города
    return [min, index2]
 
def prim(matr):
    toVisit=[i for i in range(1,len(matr))]# города кроме начального(0)
    vizited=[0]
    result=[0]# начнем с минска
    for index in toVisit:
        weight, ind=search_min(matr, vizited)
        result.append(weight)#в результат будут заноситься веса
        vizited.append(ind)# содержит карту пути
    return result
0
0 / 0 / 0
Регистрация: 01.10.2019
Сообщений: 13
21.11.2019, 11:23  [ТС]
Почему он ничего не выводит?
0
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
21.11.2019, 11:24
disconect, хм, а функцию вы вызываете или просто скопировали код и ткнули в блокнот?
0
0 / 0 / 0
Регистрация: 01.10.2019
Сообщений: 13
21.11.2019, 11:27  [ТС]
Уже понял, не могли бы вы скинуть полноценный код или что необходимо дописать. Я кажусь сейчас попрошайкой или слишком наглым, но буду вам очень благодарен
0
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
21.11.2019, 11:39
disconect, пойдём по пути наименьшего сопротивления:

Алгоритм Прима: построение min остовного дерева взвешенного связного неориентированного графа (Си -> Python)
0
0 / 0 / 0
Регистрация: 01.10.2019
Сообщений: 13
21.11.2019, 11:46  [ТС]
Почему все пишет до бесконечности?
0
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
21.11.2019, 11:48
disconect, а вы всю тему прочитали или только там, где код?
0
0 / 0 / 0
Регистрация: 01.10.2019
Сообщений: 13
21.11.2019, 11:53  [ТС]
Блин в Sublime Text писалось до бесконечности, в idle выдает ошибку
Миниатюры
Алгоритм Прима  
0
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
21.11.2019, 12:51
Кликните здесь для просмотра всего текста
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
__author__ = 'Разумов А.А.'
# Реализация алгоритма Прима на python 3
 
import random
from string import ascii_uppercase
 
 
def prima(W, city_labels = None):
    """
    Алгоритм Прима для нахождения сети дорог минимальной длины
    Дискретная алгебра, приложение 1
    """
 
    _ = float('inf')
    cities_count = len(W)
 
    # проверка на размерость таблицы связей
    for weights in W:
        assert len(weights) == cities_count
 
    # генерация имен городов
    if not city_labels:
        city_labels = [ascii_uppercase[x] for x in range(cities_count)]
 
    assert cities_count <= len(city_labels)
 
    # выбор начального города
    free_vertexes = list(range(0, len(city_labels)))
 
    starting_vertex = random.choice(free_vertexes)
    tied = [starting_vertex]
    free_vertexes.remove(starting_vertex)
 
    print('Started with %s' % city_labels[starting_vertex])
 
    road_length = 0
 
    # пока есть свободные вершины
    while free_vertexes:
        min_link = None  # соединение, образующее минимальный путь
        overall_min_path = _    # минимальный путь среди всех возможных
 
        # проход по всем уже связанным дорогой вершинам
        for current_vertex in tied:
            weights = W[current_vertex]   # связи текущей вершины с другими
 
            min_path = _
            free_vertex_min = current_vertex
 
            # проход по связанным городам
            for vertex in range(cities_count):
                vertex_path = weights[vertex]
                if vertex_path == 0:
                    continue
 
                if vertex in free_vertexes and vertex_path < min_path:
                    free_vertex_min = vertex
                    min_path = vertex_path
 
            if free_vertex_min != current_vertex:
                if overall_min_path > min_path:
                    min_link = (current_vertex, free_vertex_min)
                    overall_min_path = min_path
        try:
            path_length = W[min_link[0]][min_link[1]]
        except TypeError:
            print('Unable to find path')
            return
 
        print('Connecting %s to %s [%s]' % (city_labels[min_link[0]], city_labels[min_link[1]], path_length))
 
        road_length += path_length
        free_vertexes.remove(min_link[1])
        tied.append(min_link[1])
 
    print('Road length: %s' % road_length)
    # TODO: return graph
 
if __name__ == '__main__':
 
    _ = float('inf')
 
    W = [
        #A  B  C  D  E  F  G
        [0, 3, _, _, _, 2, _], # A
        [3, 0, 3, _, _, _, 6], # B
        [_, 3, 0, 3, 2, _, 1], # C
        [_, _, 3, 0, 5, _, _], # D
        [_, _, 2, 5, 0, 4, 3], # E
        [2, _, _, _, 4, 0, 3], # F
        [_, 6, 1, _, 3, 3, 0], # G
    ]
 
    prima(W)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.11.2019, 12:51
Помогаю со студенческими работами здесь

Графы, алгоритм Прима (Дейкстры-Прима)
Всем привет, столкнулась с такой проблемой, есть алгоритм для нахождения миним. остовного дерева, мне нужно максимального вот код...

Как переделать алгоритм Прима в алгоритм Краскала?
Здравствуйте дорогие форумчане, помогите пожалуйста переделать алгоритм Примана в алгоритм Краскала? Вот код алгоритма Примана: ...

Алгоритм Прима
Есть класс GraphEdge, отвечающий за ребро class GraphEdge { public int v1, v2; public int weight; ...

Алгоритм Прима
Всем привет! Есть ряд небольших уточнений общего характера относительного алгоритма. Говорится, что Прима будет работать на взвешенном...

Алгоритм Прима
Добрый вечер Возможно кто подскажет как решить задание через Алгоритм Прима Дан список дуг с указанием их длин. Необходимо составить...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru