Lista encadeada em C
Publicado por Alexandre (azk) (última atualização em 03/03/2016)
[ Hits: 3.157 ]
Homepage: null
Implementação de uma simples lista encadeada e dinâmica em C.
Código em en_US.
azk4n
/* a simple linked list in C
* functions: remove/insert on head/end
* show list
* erase list (free)
writer: azk4n
*/
#include <stdio.h>
#include <stdlib.h>
typedef struct NO{
int data;
struct NO *next;
}no;
// global vars
int size;
no *tmp = NULL;
// ----------
void startList(no *list){
list->next = NULL;
size = 0;
}
int testEmpty(no *list){
if(list->next == NULL) return 1;
else return 0;
}
no *malloking(){
no *new = (no *) malloc(sizeof(no));
if(!new){
printf("no memory\n");
return NULL;
}else{
printf("\ntake the nem element: ");
scanf("%d", &new->data);
printf("\n");
return new;
}
}
void insertOnEnd(no *list){
no *new = malloking();
new->next = NULL;
if(testEmpty(list)){
list->next = new;
}else{
tmp = list->next;
while(tmp->next != NULL){
tmp = tmp->next;
}tmp->next = new;
}size++;
}
void insertOnHead(no *list){
no *new = malloking();
no *oldHead = list->next;
list->next = new;
new->next = oldHead;
size++;
}
no *removeOnEnd(no *list){
if(testEmpty(list)){
printf ("\n\nempty list\n\n");
return NULL;
}else{
no *last = list->next,
*llast = list;
while(last->next != NULL){
llast = last;
last = last->next;
}
llast->next = NULL;
size--;
return last;
}
}
no *removeOnHead(no *list){
if(testEmpty(list)){
printf("\n\nempty list\n\n");
return NULL;
}else{
tmp = list->next;
list->next = tmp->next;
size--;
return tmp;
}
}
void showList(no *list){
if(testEmpty(list)){
printf("\n\nempty list\n\n");
return;
}
tmp = list->next;
system("clear");
while(tmp != NULL){
printf("%d ", tmp->data);
tmp = tmp->next;
}
printf("\n\n");
}
void freeList(no *list){
if(!testEmpty(list)){
no *nextNo,
*actualNo;
actualNo = list->next;
while(actualNo != NULL){
nextNo = actualNo->next;
free(actualNo);
actualNo = nextNo;
}
}
}
int main(){
no *list = (no*) malloc(sizeof(list));
if(!list) printf("\n\nno memory\n\n");
else startList(list);
int opt;
do{
printf("0 -> quit\n");
printf("1 -> insert on the end\n");
printf("2 -> insert on the head\n");
printf("3 -> show the list\n");
printf("4 -> remove on the end\n");
printf("5 -> remove on the head\n");
printf("6 -> free the list\n");
printf("opt: "); scanf("%d", &opt);
switch(opt){
case 1:
insertOnEnd(list);
break;
case 2:
insertOnHead(list);
break;
case 3:
showList(list);
break;
case 4:
tmp = removeOnEnd(list);
if(tmp != NULL){
printf("\nelement removed: %d\n\n", tmp->data);
free(tmp);
} break;
case 5:
tmp = removeOnHead(list);
if(tmp != NULL){
printf("\nelement removed: %d\n\n", tmp->data);
free(tmp);
}break;
case 6:
freeList(list);
startList(list);
break;
default:
if(opt != 0) printf("take valid option\n\n");
}
}while(opt != 0);
return 0;
}
Retornar o montante de um capital aplicado a juros compostos
Nenhum comentário foi encontrado.
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Atualizar Linux Mint 22.2 para 22.3 beta
Jogar games da Battle.net no Linux com Faugus Launcher
Como fazer a Instalação de aplicativos para acesso remoto ao Linux
Assisti Avatar 3: Fogo e Cinzas (4)
Conky, alerta de temperatura alta (11)









