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.
//... fprintf(stdout, "nnDigite o Nome: n--> "); scanf("%s", nome); PaMaius(nome); fprintf(stdout, "n"); //...E no fim do seu código, adicione sua função PaMaius.
//... while (escolha > 0); /* Loop Principal. */ return 0; } int PaMaius (char *t) { //...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) != ‘