Dando continuidade ao nosso Curso de Programação C, vamos nesta aula imprimir e testar nossa lista simplesmente encadeada.
Para podermos testar nossa lista encadeada falta apenas imprimir o resultado final na tela a fim de conferir se as operações foram realizadas conforme programadas. Para imprimir toda a lista basta percorrê-la até o final imprimindo na tela o valor de cada nó, assim.
/*
Procedimento para imprimir uma lista simplesmente encadeada
*/
void imprimir(No *no){
printf("\n\tLista: ");
while(no){
printf("%d ", no->valor);
no = no->proximo;
}
printf("\n\n");
}
A seguir você encontra o código completo em C para testar o funcionamento de uma lista simplesmente encadeada. Eu o encorajo a copiar este código, colar em seu editor de preferência e testá-lo, avaliar com atenção cada procedimento desenvolvido e, caso tenha ficado alguma dúvida, não exite e deixar nos comentários.
Código completo em C para a estrutura de dados lista simplesmente encadeada
/*
Código escrito por Wagner Gaspar
Agosto de 2021
Aula 246: Lista Simplesmente Encadeada: Como imprimir e testar nossa lista?
*/
typedef struct no{
int valor;
struct no *proximo;
}No;
// procedimento para inserir no início
void inserir_no_inicio(No **lista, int num){
No *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
novo->proximo = *lista;
*lista = novo;
}
else
printf("Erro ao alocar memoria!\n");
}
// procedimento para inserir no fim
void inserir_no_fim(No **lista, int num){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
novo->proximo = NULL;
// é o primeiro?
if(*lista == NULL)
*lista = novo;
else{
aux = *lista;
while(aux->proximo)
aux = aux->proximo;
aux->proximo = novo;
}
}
else
printf("Erro ao alocar memoria!\n");
}
// procedimento para inserir no meio
void inserir_no_meio(No **lista, int num, int ant){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
// é o primeiro?
if(*lista == NULL){
novo->proximo = NULL;
*lista = novo;
}
else{
aux = *lista;
while(aux->valor != ant && aux->proximo)
aux = aux->proximo;
novo->proximo = aux->proximo;
aux->proximo = novo;
}
}
else
printf("Erro ao alocar memoria!\n");
}
void imprimir(No *no){
printf("\n\tLista: ");
while(no){
printf("%d ", no->valor);
no = no->proximo;
}
printf("\n\n");
}
int main(){
int opcao, valor, anterior;
No *lista = NULL;
do{
printf("\n\t0 - Sair\n\t1 - InserirI\n\t2 - inserirF\n\t3 - InserirM\n\t4 - Imprimir\n");
scanf("%d", &opcao);
switch(opcao){
case 1:
printf("Digite um valor: ");
scanf("%d", &valor);
inserir_no_inicio(&lista, valor);
break;
case 2:
printf("Digite um valor: ");
scanf("%d", &valor);
inserir_no_fim(&lista, valor);
break;
case 3:
printf("Digite um valor e o valor de referencia: ");
scanf("%d%d", &valor, &anterior);
inserir_no_meio(&lista, valor, anterior);
break;
case 4:
imprimir(lista);
break;
default:
if(opcao != 0)
printf("Opcao invalida!\n");
}
}while(opcao != 0);
return 0;
}
