Jump to content

array de inteiros em java(contar nums diferentes)


pr0zin

Recommended Posts

Boas malta, o meu problema está no facto de eu qerer, num array de inteiros ORDENADO! quando 2 valores sao diferentes, eu qeria incrementar um contador:

static int Analisa_flag0(int vetor[])
{
 int conta=1;
 int i,j,aux,a=0;
 for ( i = 0; i < vetor.length; i++ )
   for ( j = i; j < vetor.length; j++ )
     if ( vetor[ i ] > vetor[ j ] ) { // inverte v[i] e v[j]
       int k = vetor[ i ];
       vetor[ i ] = vetor[ j ];
       vetor[ j ] = k;
     }
 for(i=0; i<vetor.length; i++) {
   if(vetor[i]!=vetor[i+1])
     conta++;
 }
 return conta;
}

já fiz print do vetor apos ordenaçao e ele de facto ficou bem ordenado, o meu problema reside no facto de quando faço

for(i=0; i<vetor.length; i++) {
 if(vetor[i]!=vetor[i+1])
   conta++;
}

isto nao funciona... podem me ajudar?

Link to comment
Share on other sites

@pr0zin

Esse título do tópico não é apropriado tendo em conta o assunto.

Ele viola a regra 2.5:

O título deve descrever a dúvida do utilizador e nunca conter frases como "Please help meeeee..." ou "duvida urgentíssima". Em caso de incumprimento o staff pode editar o tópico, ou solicitar ao autor que o edite.

Melhora-o, sff. Se precisares de ajuda, envia-me PM.

  • Vote 1

"[Os jovens da actual geração]não lêem porque não envolve um telecomando que dê para mirar e atirar, não falam porque a trapalhice é rainha e o calão é rei" autor: thoga31

Life is a genetically transmitted disease, induced by sex, with death rate of 100%.

Link to comment
Share on other sites

podes me explicar como? é qe estou mesmo embarrado nesta flag :|

consegui amigo!!!


for(i=0; i<vetor.length; i++) {
if(i+1==vetor.length)
return conta;
if(vetor[i]!=vetor[i+1])
conta++;
}
return conta;
}

adicionei esse if e resolvi o problema!

abraço

edit3: o meu problema estava no facto de quando eu acedia ao vetor[tamanho], e passava o limite do vetor! xD

podem fechar!

Edited by pr0zin
Link to comment
Share on other sites

ÃJBM a melhor maneira de fazer isso, é com 2 ciclos for? desculpa a minha chatisse xD

Sim

não ... a um array ordenado, é possível contabilizar a quantidade de números diferentes somente com um ciclo

int[] lista;

// .. ordernação

int ndiff = 0;
for (int i = 1; i < lista.length; i++)
{
 if (lista[i] != lista[i - 1])
   ndiff++;
}
Edited by HappyHippyHippo
IRC : sim, é algo que ainda existe >> #p@p
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.