Pilha Encadeada
Publicado por Ricardo Rodrigues Lucca 02/07/2003
[ Hits: 23.158 ]
Homepage: http://aventurasdeumdevop.blogspot.com.br/
Um exemplo de pilha encadeada.
// Programador: Ricardo Lucca #include "tela.h" //Declarado para se ter clrscr() e a stdio.h #include <stdlib.h> //uso para malloc #define dgetchar() getchar();getchar(); struct nodo { int elem; struct nodo *prox; } *topo, *aux; bool vazio(struct nodo *campo) { if ( campo == NULL ) return true; else return false; } void insere(void) { int x; printf("\nEntre com o numero a inserir: "); scanf(" %i", &x); aux=(struct nodo *) malloc(sizeof(aux)); aux->elem=x; aux->prox=topo; topo=aux; printf("\nElemento inserido!"); dgetchar(); } void removr(void) { if (vazio(topo)) { aux=topo; topo=topo->prox; free(aux); printf("\nRemovido com sucesso!"); dgetchar(); } } void listar(void)//faz uma busca como c fosse um vetor { if (!vazio(topo)) ; else { aux=topo; for (;(topo->prox)!=NULL;topo=topo->prox) printf("%i\n",topo->elem); printf("%i",topo->elem); printf("\nTecle algo..."); dgetchar(); topo=aux; } } int main(void) { char op; int sair=0; topo=NULL; for (;sair==0;) { clrscr(); printf("1 -> Insere na pilha\n2 -> Remove da pilha\n"); printf("3 -> Listar pilha\n4 -> Sair da pilha\n"); printf("\nDigite uma opção: "); scanf(" %c", &op); switch (op) { case '1': insere(); break; case '2': removr(); break; case '3': listar(); break; case '4': sair=1; break; default: { printf("Opção invalida! \n"); getchar(); getchar(); break; } } } return 0; }
Controle de tráfego aéreo - filas dinâmicas
Raiz cúbica pelo método de bissecção
Controle de maior idade em C++
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Meu Fork do Plugin de Integração do CVS para o KDevelop
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Criando uma VPC na AWS via CLI
Multifuncional HP imprime mas não digitaliza
Dica básica para escrever um Artigo.
Como Exibir Imagens Aleatórias no Neofetch para Personalizar seu Terminal
Mint começou a apresentar varios erros (1)
Recuperar arquivos de HD em formato RAW usando Linux (1)
Não consigo instalar linux mint [RESOLVIDO] (9)
Melhorando a precisão de valores flutuantes em python[AJUDA] (14)