Ir ao conteúdo
  • Cadastre-se
jubitso

C Como ajustar para exibir as palavras na ordem dada pelo usuário?

Recommended Posts

Este código recebe palavras e as exibe em ordem alfabética. Quero saber como posso fazer para que no trecho "Entrada atual:" ele mostre as palavras não na ordem alfabética, mas na ordem dada pelo usuário. E somente no trecho "Palavras ordenadas:" ele mostre em ordem alfabética.

 

#include <stdio.h>
#include <stdlib.h> //usado malloc
#include <string.h> //usado strcpy 
#include <ctype.h> //usado toupper
 
int main(){
 
 struct tipo{
      char Palavra[20];
      void *Prox; 
  };
  typedef struct tipo TIPO;
   
  TIPO *Inicio, *Fim, *Auxiliar, *Atual, *Anterior;
  char P[20],R='S';
 
  Inicio=NULL;
  while (R=='S'){
    system("cls");
    printf("\n > > > ORDENA PALAVRAS < < < \n");
    printf("\n Entrada atual:");
    Auxiliar=Inicio; 
    while (Auxiliar!=NULL){
      printf(" %s ",Auxiliar->Palavra);
      Auxiliar= Auxiliar->Prox;} 
    printf("\n\n Qual palavra deseja inserir? ");
    scanf(" %s",P);    
    Auxiliar=(TIPO *) malloc(sizeof(TIPO));
    strcpy(Auxiliar->Palavra,P);
    Auxiliar->Prox = NULL;
    if (Inicio == NULL){ //primeiro elemento da estrutura
      Auxiliar->Prox=NULL;
      Inicio = Auxiliar;
      Fim = Auxiliar;}
    else
      if (strcmp(P,Inicio->Palavra)<=0){ //insere no inicio
        Auxiliar->Prox = Inicio;
        Inicio = Auxiliar;}
      else
        if (strcmp(P,Fim->Palavra)>=0){ //insere no fim
          Fim->Prox = Auxiliar;
          Fim = Auxiliar;}
        else{ //insere no meio - antes do primeiro maior
          Atual = Inicio->Prox;
          Anterior = Inicio;
          while (strcmp(Atual->Palavra,Auxiliar->Palavra)<0){
            Anterior = Atual;
            Atual = Atual->Prox;}
          Anterior->Prox = Auxiliar;
          Auxiliar->Prox = Atual;}
    system("cls");
    printf("\n > > > ORDENA PALAVRAS < < < \n");
    printf("\n Palavras ordenadas: "); 
    Auxiliar=Inicio; 
    while (Auxiliar!=NULL){
      printf(" %s ",Auxiliar->Palavra);
      Auxiliar= Auxiliar->Prox; }
    printf("\n\n Digite S se deseja continuar: ");
    scanf(" %c",&R);
    R = toupper(R); }
   return 0;
}

 

  • Curtir 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

@jubitso      para isso você precisa colocar outro  vetor que armazene os nomes conforme forem digitados pelo usuário , assim você ordena um vetor para mostrar os nomes de forma ordenada e o outro para mostrar na ordem dada pelo usuário .

  • Amei 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá.

 

@devair1010,

 

2 horas atrás, devair1010 disse:

@jubitso para isso você precisa colocar outro  vetor que armazene os nomes conforme forem digitados pelo usuário , assim você ordena um vetor para mostrar os nomes de forma ordenada e o outro para mostrar na ordem dada pelo usuário .

No caso, ele está utilizando uma "lista encadeada".

 

6 horas atrás, jubitso disse:

    struct tipo {
        char Palavra[20];
        void *Prox; 
    };
    typedef struct tipo TIPO;

 

Ou seja, precisaria de outro "apontador do próximo".... um vai apontado em ordem, e o outro em sequência. Concorda?

 

No aguardo.

 

adicionado 2 minutos depois

@jubitso, ter que precisar ficar pressionando "S" não fica legal... poderia por exemplo usar uma "palavra chave", por exemplo se informar "exit" ou "sair" ou "s" mesmo...ou seja, fica lendo até que a palavra escolhida fosse informada.

  • Curtir 1
  • Amei 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá @jubitso.

 

Em 11/03/2018 às 23:57, jubitso disse:

@Simon Viegas concordo sim! Funcionou, muito obrigado!

 

Por favor, poste o seu código atual para analisarmos e também servi de base para outros programadores.

 

 

No aguardo.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora





Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×