Задание 4. Информатика. ОГЭ. Ушаков 2025-3

Просмотры: 20
Изменено: 1 февраля 2025

Между населёнными пунктами \(A, \, B, \, C, \, D, \, E, \, F\) построены дороги, протяжённость которых (в километрах) приведена в таблице.

ABCDEF
A 941317
B9 4629
C44 108
D610 33
E13283 8
F17938 

Определите длину кратчайшего пути между пунктами \(A\) и \(F.\) Передвигаться можно только по дорогам, протяжённость которых указана в таблице, два раза посещать один пункт нельзя.

Решение:

Python


def dfs(graph, beg, end, vis = [], cur = 0):
    vis += [beg]
    if beg == end:
        return cur
    min_len = 10**10
    for town, dist in graph[beg]:
        if town not in vis:
            min_len = min(min_len, dfs(graph, town, end, vis + [town], cur + dist))
    return min_len


W = ((0, 9, 4, 0, 13, 17),
     (9, 0, 4, 6, 2, 9),
     (4, 4, 0, 10, 8, 0),
     (0, 6, 10, 0, 3, 3),
     (13, 2, 8, 3, 0, 8),
     (17, 9, 0, 3, 8, 0))

towns = 'ABCDEF'

G = {towns[i]: [(towns[j], v) for j, v in enumerate(W[i]) if v] for i in range(6)}

print(dfs(G, 'A', 'F'))

Ответ: \(16\)