Pour le code ci-dessous, il s'arrête de fonctionner lorsque "n" atteint environ 100 000. J'ai besoin qu'il fonctionne jusqu'à 1 million. Je ne sais pas où ça ne va pas, je suis encore en train d'apprendre Java donc il peut y avoir des erreurs simples dans le code aussi.
public class Problem14{
public static void main(String[] args) {
int chainLength;
int longestChain = 0;
int startingNumber = 0;
for(int n =2; n<=1000000; n++)
{
chainLength = getChain(n);
if(chainLength > longestChain)
{
System.out.println("chainLength: "+chainLength+" start: "+n);
longestChain = chainLength;
startingNumber = n;
}
}
System.out.println("longest:"+longestChain +" "+"start:"+startingNumber);
}
public static int getChain(int y)
{
int count = 0;
while(y != 1)
{
if((y%2) == 0)
{
y = y/2;
}
else{
y = (3*y) + 1;
}
count = count + 1;
}
return count;
}
}