Задание № 3368

Студент

Гузенкова Анна

Задача

Успеть вовремя

Состояние

Завершено

Баллов

0

Назначено

14.06.2021, 03:08

Завершено

10.10.2021, 09:05

Реализовать поиск маршрута и расчёт схемы проезда между остановками опираясь на плановое расписание транспорта на сайте nskgortrans.ru.

Входные данные

Файл с плановым расписанием

Студенты могут как самостоятельно взять расписания с сайта для некоторого набора маршрутов, так и воспользоваться уже скачанными и обработанными данными в формате CSV (по состоянию на 2015.12.20).

вид_транспорта,номер_маршрута,направление,тип_расписания
,,,,ID_остановки,имя_остановки,  ,время_рейса1,время_рейса2,время_рейса3,...
,,,,ID_остановки,имя_остановки,  ,время_рейса1,время_рейса2,время_рейса3,...
...
вид_транспорта,номер_маршрута,направление,тип_расписания
,,,,ID_остановки,имя_остановки,  ,время_рейса1,время_рейса2,время_рейса3,...

Пример

bus,65,A,weekdays
,,,,00135,Общ. торговый центр,                            ,06:30,07:30,08:30,09:30,...
,,,,00232,Демакова ул.,                                   ,06:32,07:32,08:32,09:32,...
,,,,01184,Арбузова ул.,                                   ,06:35,07:35,08:35,09:35,...
,,,,00061,Микрорайон "Щ",                                 ,06:37,07:37,08:37,09:37,...
,,,,01184,Арбузова ул.,                                   ,06:39,07:39,08:39,09:39,...
,,,,00058,Магазин №12,                                    ,06:41,07:41,08:41,09:41,...

Параметры поиска маршрута

  • Название начальной остановки
  • Название конечной остановки и желаемое время прибытия

Задача

Система опираясь на плановое расписание должна определить набор возможных маршрутов (с пересадками) и выделить наиболее оптимальный из них (отсортировать по оптимальности), чтобы пользователь не опоздал и потратил на дорогу наименьшее возможное кол-во времени.

Подразумевается так же наличие некоторого "защитного интервала" времени для пересадок (необходимо чтобы время прибытия отстояло от времени следующего отправления на 2-5 минут).

Выходные данные

Набор маршрутов с остановками и временами посадки / пересадки / прибытия.

Тестирование

Необходимо написать полноценный набор тестов, охватывающий все варианты поиска маршрутов: приехать на вокзал Новосибирск-Главный в 3 ночи, построение маршрута с пересадкой, и т.п.

Примечания

Программа, опираясь на расписание общественного транспорта, строит возможные маршруты с пересадками по заданным начальной и конечной остановкам. При этом время прибытия не должно быть позже заданного, а время, потраченное на дорогу, должно быть минимальным. Расписание транспорта хранится в CSV-файле. Планируется графическое представление примерной схемы проезда оптимального маршрута (или всех).

Действия