eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

LinkedList Расстояние до цикла

LinkedList Расстояние до цикла

Задан связный список. Найдите расстояние от его начала до вершины, в которой начинается цикл. Если цикла нет, верните -1.

Определение связного списка:

// Java
class ListNode {
  int val;
  ListNode next;
  ListNode(int x) {
    val = x;
    next = null;
  }
}
// C++
class ListNode
{
public:
  int val;
  ListNode *next;
  ListNode(int x) : val(x), next(NULL) {}
};
// C
struct ListNode
{
  int val;
  struct ListNode *next;
};

Реализуйте функцию DistanceToCycle, которая возвращает расстояние от начала списка до вершины, в которой начинается цикл. Если цикла нет, то верните -1.

// Java
int DistanceToCycle(ListNode head)
// C, C++
int DistanceToCycle(ListNode *head)

Пример

prb9898.gif

Функция DistanceToCycle возвращает -1 так как связный список не содержит цикла.

prb10042_1.gif

Функция DistanceToCycle возвращает 2 - расстояние от начала списка до вершины, в которой начинается цикл (123).

Лимит времени 1 секунда
Лимит использования памяти 128 MiB
Автор Михаил Медведев