Back to questions
Яндекс Маркет
Middle
2
Из этих билетов можно построить единственный, неразрывный маршрут. Петлей и повторов в маршруте нет. Нужно написать программу, которая возвращает эти же объекты билетов в порядке следования по маршруту. ```javascript function getRoute(tickets = []) { const cities = new Map(); for (const ticket of tickets) { cities.set(ticket.from, ticket); } const result = []; let currentCity = startcity; while (cities.has(currentCity)) { const next = cities.get(currentCity); result.push(next); currentCity = next.to; } return result; } console.clear() console.log(getRoute([ { from: 'London', to: 'Moscow' }, { from: 'NY', to: 'London' }, { from: 'Moscow', to: 'Spb' }, ])); ```
Companies where asked
Answer from AI
sobes.tech AI
В представленном коде не хватает определения начального города startcity. Чтобы построить единственный маршрут из набора билетов, нужно:
- Найти город, из которого никто не прилетает — это и будет старт.
- Создать Map для быстрого поиска билета по городу отправления.
- Итеративно проходить по билетам, начиная с начального города, формируя маршрут.
Пример исправленного и полного решения:
function getRoute(tickets = []) {
const fromCities = new Set(tickets.map(t => t.from));
const toCities = new Set(tickets.map(t => t.to));
// Находим стартовый город — тот, который есть в from, но нет в to
let startcity = null;
for (const city of fromCities) {
if (!toCities.has(city)) {
startcity = city;
break;
}
}
const citiesMap = new Map();
for (const ticket of tickets) {
citiesMap.set(ticket.from, ticket);
}
const result = [];
let currentCity = startcity;
while (citiesMap.has(currentCity)) {
const nextTicket = citiesMap.get(currentCity);
result.push(nextTicket);
currentCity = nextTicket.to;
}
return result;
}
console.log(getRoute([
{ from: 'London', to: 'Moscow' },
{ from: 'NY', to: 'London' },
{ from: 'Moscow', to: 'Spb' },
]));
Вывод:
[
{ "from": "NY", "to": "London" },
{ "from": "London", "to": "Moscow" },
{ "from": "Moscow", "to": "Spb" }
]
Таким образом, программа восстанавливает маршрут в правильном порядке.