e-olymp 1108. Червячные дыры

Ссылка на оригинальную статью

Ссылка на Try Haxe!

Условие задачи

В 2163 году были обнаружены червячные дыры. Червячная дыра представляет собой тоннель сквозь пространство и время, соединяющий две звездные системы. Эти дыры имеют следующие свойства:

  • Червячные дыры являются односторонними.
  • Время путешествия по любому тоннелю равно нулю.
  • Червячная дыра имеет два конца, каждый из которых находится в звездной системе.
  • Звездная система в своих границах может иметь несколько концов червячных дыр.
  • По некоторой неизвестной причине начиная с нашей Солнечной системы всегда можно достигнуть любую другу звездную систему перемещаясь некоторой последовательностью червячных дыр (возможно, это потому что Земля является центром универсума).
  • Между любой парой звездных систем существует не более одной червячной дыры в любом из направлений.
  • Оба конца червячной дыры не могут находиться в одной звездной системе.
  • Каждая червячная дыра перемещает путешественника на определенное константное количество лет вперед или назад. Например, одна дыра может переместить на 15 лет в будущее, а другая на 42 года в прошлое.

Известный физик, живущий на Земле, хочет использовать червячные дыры для исследования теории Большого Взрыва. Поскольку двигатель искривления пространства еще не изобретен, невозможно напрямую путешествовать между звездными системами. Однако это можно делать при помощи червячных дыр.

Ученый хочет достигнуть цикла червячных дыр, который поможет ему попасть в прошлое. Двигаясь по этому циклу несколько раз, можно прийти ко времени, когда имел место Большой Взрыв и наблюдать его собственными глазами. Напишите программу, которая определяет существование такого цикла.

 

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

Первая строка содержит количество звездных систем $n (1 ≤ n ≤ 1000)$ и количество червячных дыр $m (0 ≤ m ≤ 2000)$. Звездные системы пронумерованы от 0 (наша солнечная система) до n — 1. Каждая червячная дыра описывается в отдельной строке и содержит три целых числа x, y и t. Эти числа указывают на возможность передвижения из звездной системы с номером x в звездную систему с номером y, при этом время изменяется на $t (-1000 ≤ t ≤ 1000)$ лет.

 

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

Cтрока содержит информацию, возможно ли в заданном множестве систем попасть в минус бесконечность во времени используя червячные дыры. Выводить следует строку «possible» или «not possible».

 

Тесты

Входные данные Выходные данные
3 3
0 1 1000
1 2 15
2 1 -42
possible
4 4
0 1 10
1 2 20
2 3 30
3 0 -60
not possible
4 4
0 1 10
1 2 20
2 3 30
3 0 -61
possible
3 3
0 1 -100
1 2 1
2 1 0
not possible

 

Код

Ход решения

Решение данной задачи сводится к нахождению отрицательного цикла в ориентированном графе. Необходимо воспользоваться алгоритмом Форда-Беллмана. Создадим вектор на n элементов и заполним его нулями. Алгоритм основан на том, что если в графе размерностью n элементов нет отрицательных циклов, то после n1 прохождения, изменения в массива кратчайших расстояний не будет. Поэтому, будем выполнять следующее n раз:

  1. Возьмем первое ребро из вектора canals, и проведем сравнение: если исходная длина пути конца данного ребра из исходного вектора distance больше, чем сумма длины пути начала вектора и стоимости прохода по данному ребру canals[].t, то изменим в векторе distance элемент с номером конца исходного ребра, и изменим индикатор изменений х, чтобы показать, что в ходе данного прохода были внесены изменения.
  2. Переходим к следующему ребру.

Если после во время последнего прохода ни разу не была изменена переменная x, то это значит, что в графе нет циклов отрицательной длины, и тогда выводим «not possible». Иначе, выводим «possible».

Latest posts by Николай Яковлев (see all)

Добавить комментарий