Ir ao conteúdo
  • Cadastre-se

Selection sort


luisfelip

Posts recomendados

Fiz um algoritmo com os princípios dos selection sort, mas a ordenação não está sendo correta. Agradeço se alguém puder ajudar-me.

#include <stdio.h>
int main(){
    int n, v[10005], i, k, menor, j, t;
    scanf("%i", &n);
    for(i=0; i<n; i++){
        scanf("%i", &v[i]);
    }
    for(i=0; i<n-1; i++){
        menor=v[i];
        for(k=i; k<n; k++){
            if(v[k]<menor) j=k;
        }
        t=v[i];
        v[i]=v[j];
        v[j]=t;
    }
    for(k=0; k<n; k++){
        printf("%i\n", v[k]);
    }
    return 0;
}

 

  • Curtir 1
Link para o comentário
Compartilhar em outros sites

@luisfelip     seu código está bom, mas precisa colocar informações para o usuario saber 
o que fazer, então coloquei essas informações.já o código não está funcionando
porque você colocou os comandos fora do lugar, ali no loop k você precisa 
colocar esses comandos dentro do loop k :

t=v[i];
v[i]=v[k];
v[k]=t;

o código ficaria assim :

#include <stdio.h>
int main(){
    int n, v[10005], i, k, menor, j, t;
    printf("   Digite a quantidade de numeros --> ");
    scanf("%i", &n);
    printf("        Serao %d numeros\n\n",n);
    for(i=0; i<n; i++){
        printf("   Digite o %d numero --> ",i+1);
        scanf("%i", &v[i]);
    }
    for(i=0; i<n-1; i++){
        for(k=i; k<n; k++){
            if(v[k] < v[i]){
                t = v[i];
                v[i] = v[k];
                v[k] = t;
            }
        }
    }
    printf("\nAqui estão Os Numeros\n");
    for(k=0; k<n; k++){
        printf(" %d numero --> %i\n",k+1,v[k]);
    }
    getch();
    return 0;
}

 

  • Curtir 2
Link para o comentário
Compartilhar em outros sites

Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades 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

×
×
  • Criar novo...