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

Реализуйте функцию MiddleElement, которая возвращает указатель на средний элемент. Если список содержит n элементов, то его средним будет элемент с индексом ceil(n / 2).

// Java
ListNode MiddleElement(ListNode head)
// C, C++
ListNode* MiddleElement(ListNode *head)

Пример

prb10380.gif

Длина списка n = 5 нечетная. Функция MiddleElement должна вернуть указатель на вершину со значением 3 (средний элемент).

prb10380_1.gif

Длина списка n = 4 четная. Функция MiddleElement должна вернуть указатель на вершину со значением 2 (средний элемент).

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