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

Определить самый дешевый путь из заданного города в другой максимум с одной пересадкой

04.11.2020, 09:12. Показов 10760. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вы знаете, что такое хитч-хайкинг? Это – путешествие на попутных машинах автостопом. Обычно, это всегда бесплатно. Но не в нашем случае. Представьте, что Вы попали в страну, где автостопа не существует, а есть только такси.

Вам надо попасть из города N в город M.
У Вас есть csv-файл, содержащий информацию о стоимости проезда между различными парами городов на такси в виде: «город-отправления;город назначения;цена».

Определите самый дешевый путь из заданного города в другой максимум с одной пересадкой.

Гарантируется, что такой путь существует в единственном варианте. Формат ввода csv-файл input.csv с ценами. В последней строки указан маршрут (откуда и куда надо добраться). Чтобы не испортить структуру csv-файла после конечного пункта маршрута стоит символ ";":

Формат вывода

Самый дешевый путь. Названия пунктов через пробел.
Пример
Ввод:

Code
1
2
3
4
5
A;B;20
C;B;50
C;A;10
A;D;40
C;B;
Вывод:

Code
1
C A B
Примечания
Маршрутный граф, описывающий дорожную ситуацию, является ориентированным, то есть, если есть прямой маршрут из города А в город В, то совсем не обязательно, что есть и обратный маршрут из города В в город А.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.11.2020, 09:12
Ответы с готовыми решениями:

Найти самый дешевый путь с первого города к городу k
Здравствуйте. Столкнулся с проблемой в задаче. Помогите пожалуйста. Дан текстовый файл: n m k n чисел m пар чисел 4 4 4 1 5 3...

Найти все такие пары станций, для которых дешевле проехать от одной до другой с одной пересадкой
Пусть вновь имеются N станций и таблица цен на проезд между ними. Требуется найти все такие пары станций, для которых дешевле проехать от...

Выяснить, как дешевле проехать от одной определённой станции до другой: напрямую или с одной пересадкой на третьей станц
Пусть вновь имеются N станций и таблица цен на проезд между ними. Требуется выяснить, как дешевле проехать от одной определённой станции до...

1
1 / 1 / 0
Регистрация: 22.04.2021
Сообщений: 1
04.12.2021, 20:11
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import csv
 
s = {}
with open('wares.csv', encoding='utf-8') as csvfile:
    reader = list(csv.reader(csvfile, delimiter=';', quotechar='"'))
    S = reader[-1]
    for i in reader[:-1]:
        if i[0] == S[0] and i[1] == S[1]:
            s[f'{i[0]} {i[1]}'] = int(i[2])
            continue
        for j in reader[:-1]:
            if i[1] == j[0] and i[0] == S[0] and j[1] == S[1]:
                s[f'{i[0]} {i[1]} {j[1]}'] = int(i[2]) + int(j[2])
    f = min(s.values())
    for i in s.keys():
        if s[i] == f:
            print(i)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.12.2021, 20:11
Помогаю со студенческими работами здесь

Как соединить все города, чтобы построить самый дешевый нефтепровод
необходимо соеденить 9 городов нафтопроводом. Возможные соеденения и стоимость строительства указаны в таблице.Как соеденить все города...

Самый дешевый путь
Вам надо попасть из города N в город M. У Вас есть csv-файл, содержащий информацию о стоимости проезда между различными парами городов на...

Самый дешёвый путь
Уважаемые знатоки и корифеи Phyton!:senor: В каждой клетке прямоугольной таблицы N×M записано некоторое число. Изначально игрок...

Самый дешёвый путь
В каждой клетке прямоугольной таблицы N×M записано некоторое число. Изначально игрок находится в левой верхней клетке. За один ход ему...

Самый дешёвый путь
Самый дешёвый путь В каждой клетке прямоугольной таблицы N×M записано некоторое число. Изначально игрок находится в левой верхней клетке....


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru