Dando continuidade ao estudo da estrutura de dados lista encadeada, vamos aprender nesta aula como inserir ordenado na estrutura de dados lista encadeada usando a estrutura Lista.
Na aula anterior nós fizemos a inserção ordenada em uma lista encadeada composta apenas de nós . Nesta aula vamos alterar o código para trabalhar também com a estrutura lista, dispensando assim a necessidade de ponteiro para ponteiro.
A estrutura lista é apresentada a seguir.
/*
Estrutura Lista
*/
typedef struct{
No *inicio;
int tam;
}Lista;
Agora que temos também a estrutura lista podemos alterar o procedimento para inserir ordenado que deixará de receber um ponteiro para ponteiro e receberá apenas um ponteiro para uma lista, assim.
/*
Procedimento para inserir ordenado
*/
void inserir_ordenado(Lista *lista, int num){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
if(lista->inicio == NULL){
novo->proximo = NULL;
lista->inicio = novo;
}
else if(novo->valor < lista->inicio->valor){
novo->proximo = lista->inicio;
lista->inicio = novo;
}
else{
aux = lista->inicio;
while(aux->proximo && novo->valor > aux->proximo->valor)
aux = aux->proximo;
novo->proximo = aux->proximo;
aux->proximo = novo;
}
lista->tam++;
}
else
printf("Erro ao alocar memoria!\n");
}
Código completo em C para a Estrutura Lista Encadeada
/*
Código escrito por Wagner Gaspar
Agosto de 2021
Aula 249: Lista Simplesmente Encadeada
Como inserir de forma ordenada COM a estrutura lista?
*/
typedef struct no{
int valor;
struct no *proximo;
}No;
typedef struct{
No *inicio;
int tam;
}Lista;
void criar_lista(Lista *lista){
lista->inicio = NULL;
lista->tam = 0;
}
// procedimento para inserir no início
void inserir_no_inicio(Lista *lista, int num){
No *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
novo->proximo = lista->inicio;
lista->inicio = novo;
lista->tam++;
}
else
printf("Erro ao alocar memoria!\n");
}
// procedimento para inserir no fim
void inserir_no_fim(Lista *lista, int num){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
novo->proximo = NULL;
// é o primeiro?
if(lista->inicio == NULL)
lista->inicio = novo;
else{
aux = lista->inicio;
while(aux->proximo)
aux = aux->proximo;
aux->proximo = novo;
}
lista->tam++;
}
else
printf("Erro ao alocar memoria!\n");
}
// procedimento para inserir no meio
void inserir_no_meio(Lista *lista, int num, int ant){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
// é o primeiro?
if(lista->inicio == NULL){
novo->proximo = NULL;
lista->inicio = novo;
}
else{
aux = lista->inicio;
while(aux->valor != ant && aux->proximo)
aux = aux->proximo;
novo->proximo = aux->proximo;
aux->proximo = novo;
}
lista->tam++;
}
else
printf("Erro ao alocar memoria!\n");
}
// procedimento para inserir ordenado
void inserir_ordenado(Lista *lista, int num){
No *aux, *novo = malloc(sizeof(No));
if(novo){
novo->valor = num;
if(lista->inicio == NULL){
novo->proximo = NULL;
lista->inicio = novo;
}
else if(novo->valor < lista->inicio->valor){
novo->proximo = lista->inicio;
lista->inicio = novo;
}
else{
aux = lista->inicio;
while(aux->proximo && novo->valor > aux->proximo->valor)
aux = aux->proximo;
novo->proximo = aux->proximo;
aux->proximo = novo;
}
lista->tam++;
}
else
printf("Erro ao alocar memoria!\n");
}
void imprimir(Lista lista){
No *no = lista.inicio;
printf("\n\tLista tam %d: ", lista.tam);
while(no){
printf("%d ", no->valor);
no = no->proximo;
}
printf("\n\n");
}
int main(){
int opcao, valor, anterior;
//No *lista = NULL;
Lista lista;
criar_lista(&lista);
do{
printf("\n\t0 - Sair\n\t1 - InserirI\n\t2 - inserirF\n\t3 - InserirM\n\t4 - InserirO\n\t5 - 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:
printf("Digite um valor: ");
scanf("%d", &valor);
inserir_ordenado(&lista, valor);
break;
case 5:
imprimir(lista);
break;
default:
if(opcao != 0)
printf("Opcao invalida!\n");
}
}while(opcao != 0);
return 0;
}
