Алгоритмы и структуры данных для начинающих: стеки и очереди


Download 81.5 Kb.
bet5/10
Sana04.02.2023
Hajmi81.5 Kb.
#1162666
TuriЛекция
1   2   3   4   5   6   7   8   9   10
Bog'liq
Алгоритмы и структуры данных для начинающих

Метод EnqueueLast

  • Поведение: Добавляет элемент в конец очереди. Этот элемент будет взят из очереди следующим при вызове метода DequeueLast.

  • Сложность: O(1).

public void EnqueueLast(T value)
{
_items.AddLast(value);
}
Метод DequeueFirst

  • Поведение: Удаляет элемент из начала очереди и возвращает его. Если очередь пустая, кидает InvalidOperationException.

  • Сложность: O(1).

public T DequeueFirst()
{
if (_items.Count == 0)
{
throw new InvalidOperationException("DequeueFirst called when deque is empty");
}

T temp = _items.Head.Value;


_items.RemoveFirst();


return temp;


}
Метод DequeueLast

  • Поведение: Удаляет элемент с конца очереди и возвращает его. Если очередь пустая, кидает InvalidOperationException.

  • Сложность: O(1).

public T DequeueLast()
{
if (_items.Count == 0)
{
throw new InvalidOperationException("DequeueLast called when deque is empty");
}

T temp = _items.Tail.Value;


_items.RemoveLast();


return temp;


}
Метод PeekFirst

public T PeekFirst()
{
if (_items.Count == 0)
{
throw new InvalidOperationException("PeekFirst called when deque is empty");
}

return _items.Head.Value;


}
Метод PeekLast

  • Поведение: Возвращает элемент с конца очереди, не изменяя ее. Если очередь пустая, кидает InvalidOperationException.

  • Сложность: O(1).

public T PeekLast()
{
if (_items.Count == 0)
{
throw new InvalidOperationException("PeekLast called when deque is empty");
}

return _items.Tail.Value;


}

Download 81.5 Kb.

Do'stlaringiz bilan baham:
1   2   3   4   5   6   7   8   9   10




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling