Olá Pessoal…
Hoje irei mostrar como fazer uma Lista Encadeada Dinâmica usando a Linguagem C, e o código podendo ser executado tanto em Linux quanto em Windows.
Primeiramente, o que seria uma lista encadeada? Simples, supondo que você tenha que fazer um programa que cadastre um número indefinido de pessoas, você irá criar uma matriz/vetor?… Errado, pois mesmo que você crie 1000 posições, isso irá consumir muito memória, desde o início do processo, sem contar que posso ter 800 pessoas, ou até mesmo 1200 pessoas, ou seja, o valor é variável, para isso é criado uma lista encadeada, que é manipulada de forma dinâmica.
Basicamente, funciona da seguinte forma, você insere um valor, em uma estrutura, que pode ser chamada de Unidade, Posição ou Nó, a partir deste, você cria a próxima posição, ou seja, você aponta para uma nova posição, por isso em cada estrutura, além dos elementos comuns (como int, char, float), existe um elemento ponteiro, que irá apontar para o próximo elemento.
Sendo que para criar as posições, deve-se usar alocação de memória, com a função MALLOC, e para excluir, é só usar o FREE, porém, a exclusão, não é tão simples, pois se você exclui a posição 3, a posição 2 agora, tem que apontar para a posição 4, que será a nova posição 3, então tem que se fazer um jogo com as variáveis. Abaixo um código fonte, adpato por mim, para ser usado tanto em Linux quanto Windows:
//Bibliotecas utilizadas #include <stdio.h> #include <stdlib.h> #include <string.h> //Se o sistema for Windows adiciona determinada biblioteca, e definindo comandos de limpar e esperar #ifdef WIN32 #include <windows.h> #define LIMPA_TELA system("cls") //Senão for Windows (ex.: Linux) #else #include <unistd.h> #define LIMPA_TELA system("/usr/bin/clear") #endif //Máximo de bytes para uma String #define BUFFER 64 //Espera 3 segundos #define ESPERA sleep(3) //Estrutura da lista que será criada typedef struct lista { char *nome; int idade; struct lista *proximo; } Dados; //Funções para manusear os dados (irão retornar dados) Dados *inicia_dados (char *nome, int idade); Dados *insere_dados (Dados *dados, char *nome, int idade); Dados *delbusca_dados(Dados *dados, char *chave); Dados *deleta_dados (Dados *dados, int nTipo); int checa_vazio (Dados *dados); //Funções para mostrar dados void exibe_dados (Dados *dados); void exibe_tamanho (Dados *nova); void busca_dados (Dados *dados, char *chave); //Funções do Menu void criavazia(void); //1 void insereinicio(void); //2 void inserefim(void); //3 void listavazia(void); //4 void prielemento(void); //5 void ultelemento(void); //6 void exibe(void); //7 void exibetam(void); //8 void deletapri(void); //9 void deleta(void); //a void delbusca(void); //b void busca(void); //c //Inicializando os dados da lista Dados *principal = NULL; //--------------------------------- // Opção '1' //--------------------------------- //Criando uma lista vazia void criavazia(void){ char *nome; int idade; //Alocando dados para uma String nome = (char *)malloc(BUFFER); //Lendo String Nome fprintf(stdout, "\n\nDigite o Nome: \n----> "); scanf("%s", nome); fprintf(stdout, "\n"); //Lendo int Idade fprintf(stdout, "Digite a Idade: \n----> "); scanf("%d", &idade); fprintf(stdout, "\n"); //Lançando os dados lidos na lista Principal free(principal); principal = inicia_dados(nome, idade); } //Iniciando os dados da lista vazia Dados *inicia_dados(char *nome, int idade) { Dados *novo; //Alocando memória para a posição atual da lista novo = (Dados *)malloc(sizeof(Dados)); //Lançando os dados lidos novo->nome = (char *)malloc(strlen(nome)+1); strncpy(novo->nome, nome, strlen(nome)+1); novo->idade = idade; //Apontando para a próxima posição da lista novo->proximo = NULL; return novo; } //--------------------------------- // Opção '2' //--------------------------------- //Inserindo no início da lista void insereinicio(void){ char *nome; int idade; //Reservando espaço para String nome = (char *)malloc(BUFFER); //Armazenando String Nome fprintf(stdout, "\n\nDigite o Nome: \n----> "); scanf("%s", nome); fprintf(stdout, "\n"); //Armazenando int Idade fprintf(stdout, "Digite a Idade: \n----> "); scanf("%d", &idade); fprintf(stdout, "\n"); //Lançando dados no ínicio da lista principal = insere_dados(principal, nome, idade); } //Inserindo dados recebidos Dados *insere_dados(Dados *dados, char *nome, int idade) { Dados *inicio; //Alocando memória para a posição atual inicio = (Dados *)malloc(sizeof(Dados)); //Lançando os dados lidos inicio->nome = (char *)malloc(strlen(nome)+1); strncpy(inicio->nome, nome, strlen(nome)+1); inicio->idade = idade; //O próximo valor aponta para a lista já existente inicio->proximo = dados; return inicio; } //--------------------------------- // Opção '3' //--------------------------------- //Inserção de dados no final de uma lista void inserefim(void) { char *nome; int idade; //Alocação de espaço para String Nome nome = (char *)malloc(BUFFER); //Armazenando String Nome fprintf(stdout, "\n\nDigite o Nome: \n----> "); scanf("%s", nome); fprintf(stdout, "\n"); //Armazenando Int Idade fprintf(stdout, "Digite a Idade: \n----> "); scanf("%d", &idade); fprintf(stdout, "\n"); //Criando listas auxiliares Dados *final,*aux; //Alocando dados para a posição final da lista final = (Dados *)malloc(sizeof(Dados)); //Setando os valores Nome e Idade final->nome = (char *)malloc(strlen(nome)+1); strncpy(final->nome, nome, strlen(nome)+1); final->idade = idade; //A pŕoxima posição será Nulo final->proximo=NULL; //A lista auxiliar será igual a Principal aux=principal; //Enquanto o próximo de auxiliar não for Nulo while(aux->proximo!=NULL){ aux=aux->proximo; } //O último valor, será Nulo, e depois apontando para //o Final aux->proximo=NULL; aux->proximo=final; } //--------------------------------- // Opção '4' //--------------------------------- //Função que testa se a lista está vazia void listavazia(void){ if (principal == NULL) fprintf(stdout, "\n\nLista esta Vazia!\n\n "); else fprintf(stdout, "\n\nLista nao esta Vazia!\n\n "); getchar(); } //--------------------------------- // Opção '5' //--------------------------------- //Mostrar o primeiro elemento da lista void prielemento(void){ fprintf(stdout, "------------------------\n"); fprintf(stdout, "Nome: %s\n", principal->nome); fprintf(stdout, "Idade: %d\n", principal->idade); fprintf(stdout, "------------------------\n"); getchar(); } //--------------------------------- // Opção '6' //--------------------------------- //Mostrando o último elemento da lista void ultelemento(void){ Dados *aux=principal; //Enquanto o próximo elemento não for NULL //Avance uma posição while(aux->proximo!=NULL){ aux=aux->proximo; } fprintf(stdout, "------------------------\n"); fprintf(stdout, "Nome: %s\n", aux->nome); fprintf(stdout, "Idade: %d\n", aux->idade); fprintf(stdout, "------------------------\n"); getchar(); } //--------------------------------- // Opção '7' //--------------------------------- //Exibindo dados da lista void exibe(void) { //Se não estiver vazio, exibe os dados if (!checa_vazio(principal)) exibe_dados(principal); } //Exibindo todos os dados do menu void exibe_dados(Dados *dados) { fprintf(stdout, "Cadastro:\n\n"); fprintf(stdout, "------------------------\n"); //Exibindo todos os valores da lista for (; dados != NULL; dados = dados->proximo) { fprintf(stdout, "Nome: %s\n", dados->nome); fprintf(stdout, "Idade: %d\n", dados->idade); fprintf(stdout, "------------------------\n"); } getchar(); } //--------------------------------- // Opção '8' //--------------------------------- //Exibindo o tamanho da lista void exibetam(void){ //Se não estiver vazio, exibe os dados if (!checa_vazio(principal)) exibe_tamanho(principal); } //Exibindo o tamanho total (bytes) e quantidade void exibe_tamanho(Dados *nova){ int aux=0, tamanho=0; fprintf(stdout, "\n------------------------\n"); //Correndo todos os valores da Lista for (; nova != NULL; nova = nova->proximo) { aux++; tamanho+=sizeof(nova); } fprintf(stdout, "Total de Elementos: %d\nTamanho Total: %d bytes\n",aux,tamanho); fprintf(stdout, "------------------------\n"); getchar(); } //--------------------------------- // Opção '9' e 'a' //--------------------------------- //Deleta o Primeiro valor void deletapri(void) { //Se não estiver vazio, deleta os dados if (!checa_vazio(principal)) principal = deleta_dados(principal,1); } //Deleta o Último valor void deleta(void) { //Se não estiver vazio, deleta os dados if (!checa_vazio(principal)) principal = deleta_dados(principal,2); } //Deleta registros da lista, Tipo 1 = Inicio, Tipo 2 = Fim Dados *deleta_dados(Dados *dados, int nTipo) { if(nTipo==1){ //Apontando para a próxima posição Dados *novo; novo = dados->proximo; //Limpando os dados free(dados->nome); free(dados); fprintf(stdout, "O primeiro registro foi deletado com sucesso.\n"); getchar(); return novo; } if(nTipo==2){ Dados *novo=dados, *aux=dados; //Se a lista estiver no fim, exclui o que restou if(novo->proximo==NULL){ free(novo); aux=NULL; } else{ //Laço de repetição para chegar no fim da lista while(novo->proximo!=NULL){ novo=novo->proximo; } //Preenchendo os dados da lista auxiliar while(aux->proximo!=novo){ aux=aux->proximo; } //Limpando os dados e apontando para nulo free(novo); aux->proximo=NULL; } fprintf(stdout, "O ultimo registro foi deletado com sucesso.\n"); getchar(); return aux; } } //--------------------------------- // Opção 'b' //--------------------------------- //Deletando valor buscado void delbusca(void) { char *chave; //Se não estiver vazio if (!checa_vazio(principal)) { chave = (char *)malloc(BUFFER); //Armazenando o valor digitado fprintf(stdout, "Digite o nome para buscar: \n--> "); scanf("%s", chave); //Deletando a chave buscada principal = delbusca_dados(principal, chave); } } //Deletando os valores buscados Dados *delbusca_dados(Dados *dados, char *chave) { int achou=0,cont=0; Dados *juntou, *aux, *nova=dados; //Correndo a lista e verificando se encontrou a string buscada, se sim, aumenta o contador e seta a variável de busca for (; nova != NULL; nova = nova->proximo) { if (strcmp(chave, nova->nome) == 0) { achou=1; cont++; } } //Se encontrou a busca if(achou==1){ int ind=0; //Correndo a lista for(ind=0;ind<cont;ind++){ //Se encontrou na primeira casa apaga a primeira casa if(strcmp(chave,dados->nome)==0){ aux=dados; dados=dados->proximo; free(aux); } //Senão, procura até encontrar else{ aux=dados; //Posiciona na frente do encontro para exclusão while(strcmp(chave,aux->nome)!=0){ aux=aux->proximo; } juntou=dados; //Enquanto o auxiliar juntou for diferente do posicionado para exclusão while(juntou->proximo!=aux){ juntou=juntou->proximo; } //Aponta para o próximo valor válido juntou->proximo=aux->proximo; free(aux); } } fprintf(stdout, "Excluido.\n"); } else fprintf(stdout, "Nenhum resultado encontrado.\n"); getchar(); return dados; } //--------------------------------- // Opção 'c' //--------------------------------- //Função que busca os dados void busca(void) { char *chave; //Senão estiver vazio a lista if (!checa_vazio(principal)) { chave = (char *)malloc(BUFFER); //Lendo o nome que será buscado fprintf(stdout, "Digite o nome para buscar: \n--> "); scanf("%s", chave); //chamando a função que irá procurar o nome busca_dados(principal, chave); } } //Percorre cada ponta da lista verificando busca void busca_dados(Dados *dados, char *chave) { int achou = 0; fprintf(stdout, "Cadastro:\n\n"); //Percorrendo todas as posições for (; dados != NULL; dados = dados->proximo) { //Se encontrou, mostra os dados if (strcmp(chave, dados->nome) == 0) { fprintf(stdout, "------------------------\n"); fprintf(stdout, "Nome: %s\n", dados->nome); fprintf(stdout, "Idade: %d\n", dados->idade); fprintf(stdout, "------------------------\n"); achou++; } } //Mostrando o resultado da busca if (achou == 0) fprintf(stdout, "Nenhum resultado encontrado.\n"); else fprintf(stdout, "Foram encontrado(s) %d registro(s).\n", achou); getchar(); } //--------------------------------- // Função Auxiliar //--------------------------------- //Função que testa se a lista esta vazia int checa_vazio(Dados *dados) { //Se a lista estiver vazia if (dados == NULL) { fprintf(stdout, "Lista vazia!\n"); getchar(); return 1; } else return 0; } //--------------------------------- // Função Principal //--------------------------------- int main(void) { char escolha; int chave=0; //Laço que irá mostrar o menu esperando uma opção (char) do { //Limpando a tela, e mostrando o menu lembrando que primeiramente, os itens estão bloqueados até que seja criada uma lista vazia LIMPA_TELA; fprintf(stdout, "\n\t\tCadastro de Pessoas\n\n"); fprintf(stdout, "Escolha uma opcao: \n"); fprintf(stdout, "1 - Criar lista vazia\n"); if(chave==1){ fprintf(stdout, "2 - Inserir no Inicio de uma lista\n"); fprintf(stdout, "3 - Inserir no Fim de uma lista\n"); } fprintf(stdout, "4 - Lista Vazia...\n"); if(chave==1){ fprintf(stdout, "5 - Exibir dados do primeiro elemento\n"); fprintf(stdout, "6 - Exibir dados do ultimo elemento\n"); fprintf(stdout, "7 - Exibir todos os valores da Lista\n"); fprintf(stdout, "8 - Exibir o tamanho da Lista\n"); fprintf(stdout, "9 - Eliminar primeiro elemento\n"); fprintf(stdout, "a - Eliminar último elemento\n"); fprintf(stdout, "b - Eliminar elemento buscado\n"); fprintf(stdout, "c - Busca Dados\n"); } fprintf(stdout, "d - Sair\n\n"); fprintf(stdout, "Resposta: "); scanf("%c", &escolha); //Se a chave for diferente de zero, porém a escolha for diferente de 1, 4 e d, a escolha será z (opção inválida) if((chave==0)&&((escolha!='1')&&(escolha!='d')&&(escolha!='4'))) escolha='z'; switch(escolha) { //Criando lista vazia case '1': chave=1; criavazia(); break; //Inserindo no início case '2': insereinicio(); break; //Inserindo no final case '3': //Se a lista não estiver vazia if(principal!=NULL){ inserefim(); } //senão inclui no inicio else{ insereinicio(); } break; //Checando se a lista está vazia case '4': listavazia(); break; //Mostrando Primeiro elemento case '5': prielemento(); break; //Mostrando Último elemento case '6': ultelemento(); break; //Exibindo todos elementos case '7': exibe(); break; //Exibindo tamanho da lista case '8': exibetam(); break; //Deleta primeiro elementos case '9': deletapri(); break; //Deleta último elemento case 'a': deleta(); break; //Deleta elemento buscado case 'b': delbusca(); break; //Buscando elementos case 'c': busca(); break; //Saindo e finalizando o programa case 'd': fprintf(stderr,"Obrigado por utilizar esse programa!\n"); fprintf(stderr,"------>Terminal de Informação<------\n\n"); ESPERA; exit(0); break; //Se foi algum valor inválido default: fprintf(stderr,"Digite uma opcao valida (pressione -Enter- p/ continuar)!\n"); getchar(); break; } //Impedindo sujeira na gravação da escolha getchar(); } while (escolha > 0); //Loop Infinito return 0; }
Um print, do programa em execução no OpenSUSE:
Pessoal, para quem também possui interesse em listas em C, recomendo acessar o blog BDFatec, do nosso amigo Chuck, lá há vários conteúdos bacanas.
Referência: Lista encadeada em C
Bom pessoal, por hoje é só.
Abraços e até a próxima.
Bom dia
estou tentando fazer uma lista com opção inserir no meio
por exemplo: já tenho lista os valores 10,12 e 15 e quando digitar 11, 13 estes valores vão ser inseridos em suas posições
este é meu código ele da alguns erros e não consigo corrigir
//cria a lista
if(primeiro == NULL)
{
primeiro=(lista*)malloc(sizeof(lista));
primeiro->info=valor;
primeiro->proximo_nodo=NULL;
primeiro->anterior_nodo=NULL;
ultimo = primeiro;
}//if(primeiro==null
else
atual = primeiro;
//procura posicao para inserir
while(atual != NULL && atual->infoproximo_nodo;
}//while
novo = (lista*)malloc(sizeof(lista));
novo->info = valor;
//insere no inicio
if(primeiro->proximo_nodo == NULL)
{
primeiro->proximo_nodo = novo;
novo->proximo_nodo = NULL;
}//primeiro == null
//insere no meio da lista
else
{
anterior->proximo_nodo = novo;
novo->proximo_nodo = atual;
}
Grande Pascoal, tudo joia?
Cara a linha que vi que está meio estranha, é essa:
“//procura posicao para inserir
while(atual != NULL && atual->infoproximo_nodo;
}//while”
Verifique se a sintaxe aqui está correta… quanto a lógica, é simples, se for a sua dúvida… Você tem o valor na posição 10 e na posição 13, e quer inserir na posição 12, você verifica a posição atual, se for menor que 12 (no caso 10), e se for, ok, ai você verifica a próxima posição, se for maior que 12 (no caso 13), ai você tem a posição que é pra inserir, é entre esses dois, ai para inserir, faça um nó auxiliar, e aponte para o próximo nó (no caso o 13), então faça um nó guardando o 12, e faça o nó do 10 apontar para o nó do 12.
Espero ter ajudado. Qualquer dúvida, estou a disposição.
Abraços. Atenciosamente,
Daniel Atilio
Eai amigo, gostaria se pode me ajudar com uma função para inserir um valor em penultimo lugar da lista, ou seja, antes do ultimo valor, se puder me ajudar eu agradeço…
Tem como modificar este que fiz para inserir no fim fazendo com que ele insira antes do ultmo?
void inserirFinal(Lista ** lista, Nodo cl)
{
Lista * aux = *lista;
Lista * anterior = NULL;
Lista * novo = (Lista *)calloc(1, sizeof(Lista));
novo->info = cl;
novo->prox = NULL;
if(*lista == NULL)
{
*lista = novo;
}
else
{
while(aux!=NULL)
{
anterior = aux;
aux = aux->prox;
}
anterior -> prox = novo;
}
}
Boa noite Newton, tente fazer assim… em um laço de repetição, guarde o último valor, e leia no lugar dele… ai depois restaure o último valor… +- assim:
while(aux!=NULL)
{
anterior = aux;
aux = aux->prox;
}
ultimo = anterior;
anterior -> prox = novo;
//… tratamento para inclusão)
anterior->prox=ultimo;
Qualquer dúvida, pode entrar em contato.
Abração.
Olá
Como eu faria se eu quisesse fazer com arquivo?
eu fiz minha struct assim:
/*variaveis globais*/
FILE *arquivo;
typedef struct cadastro
{
char *nome, email;
int tel;
}Arquivo;
Isso é redundante?
Mnha função main está assim:
int main(int argc, char *argv[])
{
char arq;
if (argc !=N)
{
printf(“Erro. Execute novamente.”);
return -1;
}
arquivo=fopen(argv[1],”a+”);
arq=argv[1];
verificacao(arq);
menu(arq);
fclose(arquivo);
return 0;
}
a função verificacacao verifica se o arquivo abriu…
Obrigado !
Boa tarde Vi,
Primeiramente, onde você está populando os dados da sua estrutura? É uma função externa?, pois da forma como vejo, está fazendo um main, com parâmetros inexistentes, dessa forma, ele nunca vai conseguir abrir arquivos.
Outra coisa, é que na estrutura, coloque um ponteiro para apontar no próximo endereço de memória, para você poder percorrer os arquivos.
No mais, acho que está tudo ok.
Muito Obrigado pelo apoio ao blog.
Abraços e bom fim de semana.
Olá no busca dados no for depois do parenteses tens um ; que não devia lá estar não sei se reparaste…
void busca_dados(Dados *dados, char *chave) {
int achou = 0;
fprintf(stdout, “Cadastro:nn”);
//Percorrendo todas as posições
for (dados != NULL; dados = dados->proximo) {
//Se encontrou, mostra os dados
if (strcmp(chave, dados->nome) == 0) {
fprintf(stdout, “————————n”);
fprintf(stdout, “Nome: %sn”, dados->nome);
fprintf(stdout, “Idade: %dn”, dados->idade);
fprintf(stdout, “————————n”);
achou++;
}
}
Boa noite Mariana,
Muito Obrigado pela observação. O ‘;’ utilizado, sem nenhum conteúdo, apenas ignora parâmetros recebidos, por exemplo:
int nVal=1;
for(nVal;nVal!=3;nVal++)
Nesse caso, como a variável do meio, já esta com o teste, e a última incrementando, podemos ignorar o primeiro parâmetro, assim economizando código e processamento. Por exemplo, tente executar a seguinte rotina:
#include
int main(){
int nVal=1;
for(;nVal!=3;nVal++){
printf(“%dn”,nVal);
}
}
Note que mesmo tendo um ‘;’ após o parênteses, o código será compilado e executado normalmente.
Mais uma vez, obrigado pela contribuição ao blog.
Tenha uma ótima semana.
Abraços.
Olá , eu estudo Linguagens de Programação e tenho um de fazer um programa sobre Listas Ligadas , e gostaria de saber se me podia ajudar
Bom dia Mariana,
Posso sim, qual seria sua dúvida?
Abraços e boa semana.
Olá bom dia..Como eu faria para criar uma função de uma busca em profundidade (sem recursividade) para buscar os nós e imprimí-los na ordem lida..
Bom dia Wagner.
Primeiramente você teria que ter a posição do nó inicial (cabeça), nisso você poderia fazer um While ou um For testando até que a lista tenha dados (ex.: aux->proximo!=NULL), dentro do for ou do laço você já poderia imprimir com o printf.
Espero ter ajudado.
Abraços e boa semana.
Caramba, ja tinha esquecido de lista encadeada e esse codigo me ajudou bastante! vlw
Boa noite Daiane.
Eu que agradeço.
Abraços.
Boa tarde…
Estou com um pouco de dificuldade… Gostaria se possível resolvesse estes dois problemas para mim…
Dese já, agradeço antecipadamente…
1 – Escreva um programa que implemente primeiro algoritmo. Sendo que o mesmo deverá armazenar vários resultados a serem apresentados em uma lista simplesmente encadeada.
2 – Escreva um programa que implemente primeiro algoritmo do trabalho prático da semana 1. Sendo que o mesmo deverá armazenar vários resultados a serem apresentados em uma lista duplamente encadeada.
Boa noite Fabiano.
Primeiro, legal você estar estudando e praticando desenvolvendo, para o primeiro problema, acho que você pode usar essa própria postagem para lhe auxiliar.
Agora para o segundo, esse algoritmo prático da semana 1, não sei o que é rs… Mas para montar uma lista duplamente encadeada, você poderia ler esse artigo: http://br.ccm.net/faq/10254-lista-duplamente-encadeada
Abraços e boa sorte.
Olá
Estou tentando resolver um problema parecido com o do Fabiano Corrêa. Já consegui desenvolver alguma coisa, mas não está funcionando como o esperado.
A ideia é que o usuário possa inserir dados em uma lista simplesmente encadeada, mas que esses dados sejam armazenados em caracteres Maiúsculos. Assim, quando o usuário for consultar os dados, eles estejam convertidos em Maiúsculo. Segue o código que já tenho:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <windows.h>
#define CLEAR_SCREEN “cls”
#define BUFFER 64
#define TAM_t 20
/* Estrutura da lista declarada para armazenar os dados. */
typedef struct lista
{
char *t;
struct lista *proximo;
} Dados;
int PaMaius (char *t)
{
}
/* Prototipo das funcoes de manuseio dos dados. */
Dados *inicia_dados(char *t);
Dados *insere_dados(Dados *dados, char *t);
void exibe_dados(Dados *t);
void busca_dados(Dados *dados, char *chave);
Dados *deleta_dados(Dados *dados);
int checa_vazio(Dados *dados);
/* Prototipo das funcoes do menu.*/
void insere(void);
void exibe(void);
void busca(void);
void deleta(void);
/* Inicializa a estrutura de dados principal. */
Dados *principal = NULL;
/* Cria a nova lista apontando o proximo no para NULL. */
Dados *inicia_dados(char *t)
{
}
/* Como a lista nao esta mais vazia, apontamos o proximo no para lista anterior. */
Dados *insere_dados(Dados *dados, char *t)
{
}
/* Percorre todos os campos da lista e imprime ate o ponteiro proximo chegar em NULL. */
void exibe_dados(PaMaius *t)
{
}
/* Percorre cada ponta comparando o t com a chave. */
void busca_dados(Dados *dados, char *chave)
{
}
/* Deleta o ultimo registro inserido. */
Dados *deleta_dados(Dados *dados)
{
}
/* Apena checa se a lista e NULL ou nao. */
int checa_vazio(Dados *dados)
{
}
/* Obtem os dados necessarios para chamar as funcoes de manuseio de dados. */
void insere(void)
{
}
void exibe(void)
{
}
void busca(void)
{
}
void deleta(void)
{
}
int main(void)
{
}
Se você puder me ajudar a ajustar esse código, agradeço muito!!
Boa noite.
O que não estaria funcionando, apenas o deixar maiúsculo? Se sim, ao invés de utilizar sua função PaMaius, utilize a toupper, dentro da biblioteca ctype.ch. Referência: http://www.findsourcecode.com/c-programming/convert-character-from-lowercase-to-uppercase/
Agora se tiver outro problema, qual seria? (para eu poder analisar o código e verificar)
Abraços.
Olá
Na verdade, eu tinha dois códigos separados e os dois estavam funcionando bem. Mas eu precisava juntar os dois, e aí é que não deu muito certo.
O código que eu utilizei para converter em maiúsculo foi esse (está ok):
#include<stdlib.h>
#include<stdio.h>
#define TAM_TEXTO 20
int PaMaius(char *);
int main ( void )
{
}
int PaMaius (char *t)
{
}
E eu fiz um outro código, um lista simplesmente encadeada para armazenar nomes e números de telefone. Esse aqui:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <windows.h>
#define CLEAR_SCREEN “cls”
#define BUFFER 64
/* Estrutura da lista declarada para armazenar os dados. */
typedef struct lista
{
char *nome;
int telefone;
struct lista *proximo;
} Dados;
/* Prototipo das funcoes de manuseio dos dados. */
Dados *inicia_dados(char *nome, int telefone);
Dados *insere_dados(Dados *dados, char *nome, int telefone);
void exibe_dados(Dados *dados);
void busca_dados(Dados *dados, char *chave);
Dados *deleta_dados(Dados *dados);
int checa_vazio(Dados *dados);
/* Prototipo das funcoes do menu.*/
void insere(void);
void exibe(void);
void busca(void);
void deleta(void);
/* Inicializa a estrutura de dados principal. */
Dados *principal = NULL;
/* Cria a nova lista apontando o proximo no para NULL. */
Dados *inicia_dados(char *nome, int telefone)
{
}
/* Como a lista nao esta mais vazia, apontamos o proximo no para lista anterior. */
Dados *insere_dados(Dados *dados, char *nome, int telefone)
{
}
/* Percorre todos os campos da lista e imprime ate o ponteiro proximo chegar em NULL. */
void exibe_dados(Dados *dados)
{
}
/* Percorre cada ponta comparando o nome com a chave. */
void busca_dados(Dados *dados, char *chave)
{
}
/* Deleta o ultimo registro inserido. */
Dados *deleta_dados(Dados *dados)
{
}
/* Apena checa se a lista e NULL ou nao. */
int checa_vazio(Dados *dados)
{
}
/* Obtem os dados necessarios para chamar as funcoes de manuseio de dados. */
void insere(void)
{
}
void exibe(void)
{
}
void busca(void)
{
}
void deleta(void)
{
}
int main(void)
{
}
E aí tirei a parte do telefone e tentei modificar para armazenar somente os nomes (ou um texto qualquer que o usuário preferir). Tentei inserir o código de converter para maiúsculo, pois o usuário poderia digitar um texto em minúsculo, mas quando, no menu, ele escolhesse por exemplo a opção de exibir lista, os resultados precisam estar convertidos para maiúsculo.
Foi então que eu fiquei um pouco confusa. Fiz aquele código que eu mostrei no post anterior, mas ele não está funcionando.
Preciso de uma lista simplesmente encadeada para armazenar o que o usuário digitar, mas na hora de apresentar os resultados da lista, os caracteres precisam estar em maiúsculo.
Grata pela atenção.
Abraços
Boa noite Elisa.
Entendi, então o problema seria deixar como maiúsculo… pois bem, na declaração das funções, adicione o PaMaius, seria o primeiro paso:
O segundo passo é na função “insere”, logo após ler o nome, chame sua função PaMaius.
E no fim do seu código, adicione sua função PaMaius.
Espero ter ajudado. Boa sorte.
Abraços.
Obrigada pela ajuda. Ajudou muito mesmo!
Consegui terminar o código.
Obrigada
Abraços.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <windows.h>
#define CLEAR_SCREEN “cls”
#define BUFFER 64
/* Estrutura da lista declarada para armazenar os dados. */
typedef struct lista
{
char *nome;
} Dados;
/* Prototipo das funcoes de manuseio dos dados. */
Dados *inicia_dados(char *nome);
Dados *insere_dados(Dados *dados, char *nome);
void exibe_dados(Dados *dados);
void busca_dados(Dados *dados, char *chave);
Dados *deleta_dados(Dados *dados);
int checa_vazio(Dados *dados);
/* Prototipo das funcoes do menu.*/
void insere(void);
void exibe(void);
void busca(void);
void deleta(void);
/* Inicializa a estrutura de dados principal. */
Dados *principal = NULL;
/* Cria a nova lista apontando o proximo no para NULL. */
Dados *inicia_dados(char *nome)
{
}
/* Como a lista nao esta mais vazia, apontamos o proximo no para lista anterior. */
Dados *insere_dados(Dados *dados, char *nome)
{
}
/* Percorre todos os campos da lista e imprime ate o ponteiro proximo chegar em NULL. */
void exibe_dados(Dados *dados)
{
}
/* Percorre cada ponta comparando o nome com a chave. */
void busca_dados(Dados *dados, char *chave)
{
}
/* Deleta o ultimo registro inserido. */
Dados *deleta_dados(Dados *dados)
{
}
/* Apena checa se a lista e NULL ou nao. */
int checa_vazio(Dados *dados)
{
}
int PaMaius (char t)
{
int i=0;
while ((t+i) != ‘