Ir ao conteúdo
  • Cadastre-se

Vetor não pode conter elementos repetidos


Posts recomendados

Salve galera do Clube do Hardware, estou tentando escrever um programa que consiste em criar um vetor que lê do teclado, por exemplo, 4 números, sendo que, caso haja um valor repetido, não necessariamente adjacente, o programa peça pra substituí-lo. Meu programa funciona em parte, caso os elementos repetidos sejam adjacentes, o programa substitui.......o problema é que se eu volto a entrar com o mesmo número ele não pede pra substituir.....e imprime o vetor com os elementos repetidos. Desde já agradeço a ajuda.  

6_13.txt

Link para o comentário
Compartilhar em outros sites

Boa tarde, como se trata de um programa simples fica melhor ver um exemplo,

Por questões didáticas fiz a solução em cima do código que você anexou observe livremente abaixo as adaptações:

#include <stdio.h>
int main( void )
{

    int i,j,k,x; i = j = k = x = 0x0;   ///Sempre iniciar as variáveis.
    int A[ 0x4 ] = { 0x0 };             ///
    int B[ 0x4 ] = { 0x0 };             ///
	
//#1 FOR
    for( i = 0x0; i < 0x4; i++ )
        {
            printf( "enter a number: " );
            scanf( "%d",&A[ i ] );
            B[ i ] = A[ i ];

//#2 FOR 
        for( j = 0x0; j <= i; j++ ) ///i é o limite, é o número de entredas,
            {                       ///
                if( B[ j ] == B[ j + 0x1 ] )
                    {
                        printf ("number %d is repeated, type other: ", B[ j ] );
                        scanf( "%d", &B[ j ] ),
                        j = 0x0; ///Este atributo garante a re-consulta 
                    }
            }//2# FOR END
        } ///#1 FOR END aninhando o #2
    system("pause");
    return( 0x0 );
}

 

Link para o comentário
Compartilhar em outros sites

@Mauro Britivaldo , em primeiro lugar muito obrigado pela dica. Agora, o programa realmente funciona, porém para números repetidos adjacentes, por exemplo 1233; 1158; 1229. Quando o vetor é da forma, por exemplo; 2620; 1081, ele não substitui. Vou tentar ver se consigo descobrir onde está o erro. Obrigado mais uma vez. 

adicionado 0 minutos depois

@MassakiMsk , valeu mano, tentarei aqui.

Link para o comentário
Compartilhar em outros sites

Eu acho que resolvi 

#include <stdio.h>
int main( void )
{

    int i,j,k,x; i = j = k = x = 0x0;   ///Sempre iniciar as variáveis.
    int A[ 0x4 ] = { 0x0 };             ///
    int B[ 0x4 ] = { 0x0 };             ///
    int aux = 0x0;

//#1 FOR
    for( i = 0x0; i < 0x4; i++ )
        {
            printf( "enter a number: " );
            scanf( "%d",&A[ i ] );
            B[ i ] = A[ i ];

//#2 FOR
        for( aux = j = 0x0; j <= i; j )///i é o limite, é o número de entradas,
            {                          ///

                if( aux != j && B[ j ] == B[ aux ] )///aux != j garante a não auto  comparação,
                    {                               ///
                        printf ("number %d is repeated, type other: ", B[ j ] ); printf("Aux := %d ", aux );
                        scanf( "%d", &B[ j ] ),
                        aux = j = 0x0;   ///Este atributo garante a re-consulta
                    }
                if( aux++ == i )aux = 0, j++;///O mesmo elemento x vai ser consultado todo vetor i-elementos.
                                            /// j <= i Vezes por exemplo se tem 3 elementos haverá 9 loops
            }//2# FOR END
        } ///#1 FOR END aninhando o #2

    ///Exibir vetor resultante
    for( i = 0x0; i < 0x4; i++ )
      printf("%d ", B[ i ] );

    system("pause");
    return( 0x0 );
}
  • Curtir 1
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...