Ir ao conteúdo
  • Cadastre-se

C Pilha alocada dinamicamente com strings


Posts recomendados

Boa noite!

 

Alguém poderia me ajudar com o código abaixo?

 

Preciso adaptá-lo para que seja possível empilhar strings.

 

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

/*Declaração do tipo nó para a pilha, composto de
ponteiro para o próximo nó e de um campo para dado
*/
typedef struct elemento {

       int dado;
       struct elemento *proximo;

       } elemento;

elemento *topo = NULL; //Ponteiro para o topo da pilha
elemento *alocar = NULL; //Ponteiro para fazer alocação

/*Inserção de elementos na pilha
Parâmetro dado: é um int */

void push(int dado) {

    alocar = malloc(sizeof(struct elemento)); //aloca memória

    if (alocar == NULL) { //Se não for possível fazer a alocação, sai do programa
       printf("push: Falta de memória\n");
       return -1;
    }

    alocar->dado = dado; //Copia o dado para o novo nó alocado

     if (topo == NULL) { //Se não houver elemento ainda na pilha, insere na base
         topo = alocar;
         topo->proximo = NULL;

     }
     else

     {
         alocar->proximo = topo; //Aponta o próximo para o "antigo" topo da pilha
         topo = alocar;          //Aponta o ponteiro de topo para o dado que foi alocado

     }
}

/*
Retira elementos da pilha
*/
int pop(int *removido) {

    if(topo){
        *removido = topo->dado;
        topo = topo->proximo;
        return 0;
    }
    else{
        printf("pop: Pilha vazia.\n");
        return -1;
    }

    }

/*Imprime todos os elementos da pilha na tela
na ordem de retirada
*/
void imprimir() {
     elemento *ponteiro = topo;

     if (ponteiro == NULL){
        printf("imprimir: Pilha vazia.\n");
        return -1;
     }

    printf("\nPilha:\n");

    while (ponteiro) {
           printf("%d\n", ponteiro->dado);
           ponteiro = ponteiro->proximo;
          }
     }

int main() {

    int dado;
    int rem = 0;
    int ret = 0;

    ret = pop(&rem); //Tenta remover dado da pilha vazia

    if(ret == 0){
        printf("\nmain:Saiu da pilha: %d\n", rem);
        imprimir();
    }

    printf("\nInserir: ");
    scanf("%d", &dado);
    push(dado);
    imprimir();

    printf("\nInserir: ");
    scanf("%d", &dado);
    push(dado);
    imprimir();

    ret = pop(&rem);

    if(ret == 0){
        printf("\nmain: Saiu da pilha: %d\n", rem);
        imprimir();
    }

    ret = pop(&rem);

    if(ret == 0){
        printf("\nmain: Saiu da pilha: %d\n", rem);
		imprimir();
    }

    printf("\nRetirar: ");

    ret = pop(&rem);

    if(ret == 0){
        printf("\nmain: Saiu da pilha: %d\n", rem);
		imprimir();
    }
  }

 

Link para o comentário
Compartilhar em outros sites

5 minutos atrás, allanxd disse:

Esse código foi você quem fez?

 

Parece ser uma variação desse aqui postado em 2010: https://www.vivaolinux.com.br/script/Pilha-algoritmos-push-pop-e-imprimir-explicados

 

O código é bem similar com algumas coisas diferentes, até os comentários são praticamente iguais com algumas alterações. Mas o do link já era com vetor de caracteres ao invés de int.

Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...