Найкоротший шлях
Дуже проста
Обмеження на час виконання 2 секунди
Обмеження на використання пам'яті 128 мегабайтів
Задано неорієнтовний граф. Знайдіть найкоротший шлях від вершини a до вершини b.
Вхідні дані
У першому рядку знаходиться два цілих числа n та m (1 ≤ n ≤ 5 * 10^4
, 1 ≤ m ≤ 10^5
) - кількість вершин та ребер відповідно. У другому рядку йдуть цілі числа a та b - стартова та кінцева вершина відповідно. Далі йде m рядків, які описують ребра.
Вихідні дані
Якщо шляху між a та b немає, то виведіть -1. Інакше виведіть у першому рядку довжину l найкоротшого шляху міжу цими двома вершинами у ребрах, а у другому рядку виведіть l + 1 число - вершини цього шляху.
Приклади
Вхідні дані #1
Відповідь #1
Вхідні дані #2
Відповідь #2
Відправки 10K
Коефіцієнт прийняття 40%