Pilha dinâmica
Como visto na página sobre pilha estática, pilhas são estruturas de dados que adotam a política LIFO (Last in, first out). Assim, as operações de remoção e inserção acontecem em um único ponto: o topo da pilha.
Enquanto a implementação estática da pilha ocorre em um vetor, a implementação dinâmica tem como principal vantagem a possibilidade de se alocar mais memória em tempo de execução - e de liberar memória, se for necessário.
🔋 Declarando a pilha dinâmica
#include<stdio.h>
#include<stdlib.h>
typedef struct{
int chave;
} REGISTRO;
typedef struct item{
REGISTRO r;
struct item *ant;
} ITEM;
typedef struct{
ITEM *topo;
int tam;
} PILHA;
*️⃣ Funções de manipulação da pilha
Inicializar a pilha
void inicializarPilha(PILHA *p){
p->topo = NULL;
p->tam = 0;
}
A variável topo
recebe o valor NULL
por ser tratar de um ponteiro. Já a variável tam
recebe o valor 0
.
Inserir (ou empilhar)
ITEM* criarItem(REGISTRO r){
ITEM* novo = (ITEM*) malloc(sizeof(ITEM));
if(novo){
novo->r = r;
novo->ant = NULL;
return novo;
}
return NULL;
}
void empilhar(PILHA *p, REGISTRO r){
ITEM* novo = criarItem(r);
novo->ant = p->topo;
p->topo = novo;
}
Remover (ou desempilhar)
void desempilhar(PILHA *p){
if(p->topo){
ITEM* deletar = p->topo;
p->topo = p->topo->ant;
p->tam--;
free(deletar);
}
}
Imprimir
void imprimir(PILHA *p){
ITEM* pos = p->topo;
while(pos){
printf("%d\n", pos->r.chave);
pos = pos->ant;
}
}
🧑🏻💻 Testando a pilha
int main(void){
PILHA p;
inicializarPilha(&p);
empilhar(&p, (REGISTRO){10});
empilhar(&p, (REGISTRO){20});
empilhar(&p, (REGISTRO){30});
empilhar(&p, (REGISTRO){40});
desempilhar(&p);
empilhar(&p, (REGISTRO){50});
imprimir(&p);
}