Динамический стек на базе динамического массива
Завершено
3
03.04.2024, 11:00
17.04.2024, 06:59
Реализовать стек на базе динамического массива.
typedef struct tStack {
/* ... */
} Stack;
typedef void *Pointer;
/* Создать пустой стек */
void stack_create(Stack *pstack);
/* Уничтожить стек, освободив выделенную память */
void stack_destroy(Stack *pstack);
/* Поместить значение value на вершину стека */
void stack_push(Stack *pstack, Pointer value);
/* Возвращает количество элементов в стеке (0, если стек пуст) */
size_t stack_size(Stack *pstack);
/* Снять значение с вершины стека. Если стек пуст, возвращает 0 */
Pointer stack_pop(Stack *pstack);
/*
* Возвращает значение с вершины стека, не удаляя его из стека.
* Если стек пуст, возвращает 0
*/
Pointer stack_peek(Stack *pstack);
Тесты с помощью assert
.