Fila
Publicado por Ricardo Rodrigues Lucca 02/07/2003
[ Hits: 13.639 ]
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;
}
Algoritmo estatístico para cálculo de PI em C
Nenhum comentário foi encontrado.
Como criar um make.conf no Gentoo (para iniciantes)
Como instalar o Open WebUI para Ollama no Gentoo (com systemd)
INSTALAR (e jogar) COUNTER STRIKE 1.6 (install cs 1.6) NO LINUX
A tragédia silenciosa das distribuições baseadas (ou “agregadas”)
Removendo o bloqueio por erros de senha no Gentoo (systemd)
Papel de Parede Animado no KDE Plasma 6 (Com dicas para Gentoo)
Homebrew: o gerenciador de pacotes que faltava para o Linux!
Removendo a trava de versão do Project Brutality para GZDoom/UZDoom
Acelere a compilação no Gentoo com distcc (guia para Systemd)
ATUALIZAÇÃO DO KERNEL LINUX (2)
[Matemática] o que seria algo mais poderoso do que uma função? [RESOLV... (5)









