Você está aqui: C ::: Estruturas de Dados ::: Pilhas

Como criar uma pilha em C usando um vetor (array) - Estruturas de Dados em C

Quantidade de visualizações: 1008 vezes
A Pilha é uma estrutura de dados do tipo LIFO - Last-In, First-Out (Último a entrar, primeiro a sair). Neste tipo de estrutura, o último elemento a ser inserido é o primeiro a ser removido. Veja a imagem a seguir:



Embora seja mais comum a criação de uma estrutura de dados do tipo Pilha de forma dinâmica (usando ponteiros e referências), nesta dica eu mostrarei como podemos criá-la em C usando um array, ou seja, um vetor. No exemplo eu usei inteiros, mas você pode modificar para o tipo de dados que você achar mais adequado.

Veja o código completo para o programa C que cria uma pilha usando um vetor de ints. Veja que o tamanho do vetor é informado com um #define. Note também a lógica empregada na construção das funções empilhar(), desempilhar() e imprimir_pilha():

#include <stdio.h>
#include <stdlib.h>
#include <locale.h>

// tamanho máximo da pilha
#define TAM_MAX 5

// função usada para empilhar um novo valor na pilha
void empilhar(int valor, int *topo, int pilha[]){
  // a pilha já está cheia?
  if(*topo == (TAM_MAX - 1)){
    printf("\nA pilha está cheia.\n");
  }
  else{
    *topo = *topo + 1;
    pilha[*topo] = valor;
  }
}

// função usada para desempilhar o elemento no topo da pilha
int desempilhar(int *topo, int pilha[]){
  int valor;

  // a pilha está vazia? 
  if(*topo == -1){
    printf("\nPilha vazia\n");
    exit(1);
  }
  else{
    valor = pilha[*topo];
    *topo = *topo - 1;
  }
  
  return valor;
}

// função usada para imprimir a pilha
void imprimir_pilha(int *topo, int pilha[]){
  int i;
	
  if(*topo == -1){
    printf("\nPilha vazia\n");
    exit(1);
  } 
  else {
    // vamos percorrer todos os elementos da pilha
    for (i = 0; i <= *topo; i++) {
      printf("Item[%d]: %d\n", (i + 1), pilha[i]);
    }
  }
}

int main(int argc, char *argv[]){
  setlocale(LC_ALL,""); // para acentos do português

  // vamos criar uma nova pilha 


Ao executar este código C nós teremos o seguinte resultado:

Itens presentes na Pilha
Item[1]: 34
Item[2]: 52
Item[3]: 18

O elemento desempilhado foi: 18
O elemento desempilhado foi: 52

Itens presentes na Pilha
Item[1]: 34

Link para compartilhar na Internet ou com seus amigos:

Desafios, Exercícios e Algoritmos Resolvidos de C

Veja mais Dicas e truques de C

Dicas e truques de outras linguagens

E-Books em PDF

E-Book 350 Exercícios Resolvidos de Java - PDF com 500 páginas
Domine lógica de programação e a linguagem Java com o nosso E-Book 350 Exercícios Exercícios de Java, para você estudar onde e quando quiser.

Este e-book contém exercícios resolvidos abrangendo os tópicos: Java básico, matemática e estatística, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book
E-Book 650 Dicas, Truques e Exercícios Resolvidos de Python - PDF com 1.200 páginas
Domine lógica de programação e a linguagem Python com o nosso E-Book 650 Dicas, Truques e Exercícios Exercícios de Python, para você estudar onde e quando quiser.

Este e-book contém dicas, truques e exercícios resolvidos abrangendo os tópicos: Python básico, matemática e estatística, banco de dados, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book

Linguagens Mais Populares

1º lugar: Java
2º lugar: Python
3º lugar: C#
4º lugar: PHP
5º lugar: C
6º lugar: Delphi
7º lugar: JavaScript
8º lugar: C++
9º lugar: VB.NET
10º lugar: Ruby



© 2025 Arquivo de Códigos - Todos os direitos reservados
Neste momento há 34 usuários muito felizes estudando em nosso site.