Fila
Publicado por Ricardo Rodrigues Lucca 02/07/2003
[ Hits: 13.300 ]
Homepage: http://aventurasdeumdevop.blogspot.com.br/
Codigo Fonte de um programa que usa fila encadeada.
//tela.h é uma biblioteca pessoal minha que uso, no caso, pra ter stdio.h declarada e clrscr() #include "tela.h" #include <stdlib.h> #define dgetchar() getchar();getchar(); typedef int elemento; struct nodo { elemento elem; struct nodo *prox; } *inicio, *fim, *aux; bool vazio(struct nodo *campo) { if ( campo == NULL ) return true; else return false; } void insere(void) { elemento x; printf("Digite o elemento a inserir: "); scanf(" %d",&x); aux=(struct nodo *) malloc(sizeof(aux)); aux->elem=x; aux->prox=NULL; if (vazio(inicio)) inicio=fim=aux; else { fim->prox=aux; fim=fim->prox; } printf("Inserido com sucesso!"); dgetchar(); } void removr(void) { if (vazio(inicio)) { printf("Fila vazia!\n"); dgetchar(); } else { aux=inicio; inicio=inicio->prox; free(aux); printf("Removido com sucesso!\n"); dgetchar(); } } void listar(void) { if (!vazio(inicio)) { for (aux=inicio;!vazio(aux->prox);aux=aux->prox) printf("%d\n",aux->elem); printf("%d\n",aux->elem); } else printf("Fila Vazia!"); dgetchar(); } int main(void) { char op; int sair=0; inicio=fim=NULL; for (;sair==0;) { clrscr(); printf("1 -> Insere na fila\n2 -> Remove da fila\n"); printf("3 -> Listar fila\n4 -> Sair da fila\n"); printf("\nDigite uma opçao: "); 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çao invalida! \n"); dgetchar(); break; } } } return 0; }
Nenhum comentário foi encontrado.
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
Efeito "livro" em arquivos PDF
Como resolver o erro no CUPS: Unable to get list of printer drivers
Flatpak: remover runtimes não usados e pacotes
Mudar o gerenciador de login (GDM para SDDM e vice-versa) - parte 2
estou com chromebook legalzinho. (2)
Estou com sede em aprender sobre o nosso querido Linux. (1)
big linux sem audio como resolver (2)
Como faz para dar um update-grub por shell script [RESOLVIDO] (3)
[Python] Automação de scan de vulnerabilidades
[Python] Script para analise de superficie de ataque
[Shell Script] Novo script para redimensionar, rotacionar, converter e espelhar arquivos de imagem
[Shell Script] Iniciador de DOOM (DSDA-DOOM, Doom Retro ou Woof!)
[Shell Script] Script para adicionar bordas às imagens de uma pasta