Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
MatheusINF

C Algoritmo ordenação de um vetor

Recommended Posts

Postado (editado)

Bom galera meu algoritmo está quase pronto , porém no final após a pessoa digitar um número Y, Preciso verificar se o elemento está presente no vetor coisa que já fiz, e caso não esteja presente eu preciso colocar o elemento Y no vetor e deixa-lo em ordem crescente, alguem sabe como fazer?

#include <stdio.h>

int main()
{
    // VARIAVEIS
    int n,i,j,temp,cont;


    // INICIO
    printf("Digite quantos valores o arranjo ira ter: ");
    scanf("%d",&n);

    float x[n],y;

    printf("\n\n");
        for(i=0; i<n; i++){
            printf("Digite o valor da posicao %d do arranjo: ",i+1);
            scanf("%f",&x[i]);
        }

    for (i=0;i<n; i++)
    for(j=i+1;j<n;j++)
    {
    if (x[i]>x[j])
    {
    temp=x[i];
    x[i]=x[j];
    x[j]=temp;
    }
    }

    printf("\nVetor em ordem crescente: \n");
    for(i=0;i<n;i++)
    printf(" %.1f - ",x[i]);

    printf("\n\nDigite um valor aleatorio:  ");
    scanf("%f",&y);


    cont=0;
    i=0;
    while ( i == 0 &&  cont < n)
   {
       if (x[cont]== y)
               i = 1;
        cont++;
    }

    if (i ==1)
    printf("\t\nO elemento %.1f pertence ao conjunto.\n",y);
    else

return 0;
}

 

Editado por MatheusINF
  • Amei 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

@MatheusINF     na hora de criar o vetor   x   coloque mais uma posição , assim :

float x[n+1],y;

e depois de verificar que o y não está presente e então quando for inserir o   y   coloque assim  :

x[n]=y;

e em seguida faça novamente a ordenação do vetor .

  • Obrigado 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

@devair1010 Vlwww, caso alguém precise no futuro

#include <stdio.h>

int main()
{
    // VARIAVEIS
    int n,i,j,temp,cont;


    // INICIO
    printf("Digite quantos valores o arranjo ira ter: ");
    scanf("%d",&n);

    float x[n+1],y;

    printf("\n\n");
        for(i=0; i<n; i++){
            printf("Digite o valor da posicao %d do arranjo: ",i+1);
            scanf("%f",&x[i]);
        }

    for (i=0;i<n; i++)
    for(j=i+1;j<n;j++)
    {
    if (x[i]>x[j])
    {
    temp=x[i];
    x[i]=x[j];
    x[j]=temp;
    }
    }

    printf("\nVetor em ordem crescente: \n");
    for(i=0;i<n;i++)
    printf(" %.1f - ",x[i]);

    printf("\n\nDigite um valor aleatorio:  ");
    scanf("%f",&y);


    cont=0;
    i=0;
    while ( i == 0 &&  cont < n)
   {
       if (x[cont]== y)
               i = 1;
        cont++;
    }

    if (i ==1)
    printf("\t\nO elemento %.1f pertence ao conjunto.\n",y);
    else{
        x[n]=y;
        for (i=0;i<n+1; i++)
        for(j=i+1;j<n+1;j++)
        {
        if (x[i]>x[j])
        {
        temp=x[i];
        x[i]=x[j];
        x[j]=temp;
        }
        }
        printf("\nVetor em ordem crescente: \n");
        for(i=0;i<n+1;i++)
        printf(" %.1f - ",x[i]);
    }


return 0;
}

 

  • Obrigado 1

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






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

×