Задание 4. Информатика. ОГЭ. Ушаков 2025-3
- Просмотры: 20
- Изменено: 1 февраля 2025
Между населёнными пунктами \(A, \, B, \, C, \, D, \, E, \, F\) построены дороги, протяжённость которых (в километрах) приведена в таблице.
A | B | C | D | E | F | |
---|---|---|---|---|---|---|
A | 9 | 4 | 13 | 17 | ||
B | 9 | 4 | 6 | 2 | 9 | |
C | 4 | 4 | 10 | 8 | ||
D | 6 | 10 | 3 | 3 | ||
E | 13 | 2 | 8 | 3 | 8 | |
F | 17 | 9 | 3 | 8 |
Определите длину кратчайшего пути между пунктами \(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\)