Стек

Структура LIFO, где последний добавленный элемент удаляется первым.

A stack is an abstract data type that serves as a collection of elements with two principal operations: 'push' (adds an element) and 'pop' (removes the most recently added element). It is essential for managing function calls, undo mechanisms, and expression parsing.

        graph LR
  Center["Стек"]:::main
  Rel_queue["queue"]:::related -.-> Center
  click Rel_queue "/terms/queue"
  Rel_array["array"]:::related -.-> Center
  click Rel_array "/terms/array"
  classDef main fill:#7c3aed,stroke:#8b5cf6,stroke-width:2px,color:white,font-weight:bold,rx:5,ry:5;
  classDef pre fill:#0f172a,stroke:#3b82f6,color:#94a3b8,rx:5,ry:5;
  classDef child fill:#0f172a,stroke:#10b981,color:#94a3b8,rx:5,ry:5;
  classDef related fill:#0f172a,stroke:#8b5cf6,stroke-dasharray: 5 5,color:#94a3b8,rx:5,ry:5;
  linkStyle default stroke:#4b5563,stroke-width:2px;

      

🧠 Проверка знаний

1 / 1

🧒 Простыми словами

Представь стопку блинов. Ты кладешь новый блин сверху и ешь сначала тот, что сверху. Последний положенный блин съедается первым!

🤓 Expert Deep Dive

Переполнение стека (Stack Overflow) возникает при слишком глубокой рекурсии. Оптимизация хвостовой рекурсии предотвращает рост стека. Lock-free стек Трейбера использует CAS для конкурентности.

📚 Источники