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

LinkedList Цикл

LinkedList Цикл

Ліміт часу 1 секунда
Ліміт використання пам'яті 128 MiB

Задан связный список. Содержит ли он цикл?

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

// 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;
};

Реализуйте функцию hasCycle, которая возвращает 1 если связный список содержит цикл и 0 иначе. Изменять значения элементов списка запрещено.

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

Пример

prb9898.gif

Функция hasCycle возвращает 0, так как связный список не содержит цикл.

prb10042_1.gif

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

Автор Михаил Медведев