Programm schmeißt eine Exception-warum?

Eiche89

Mitglied
Diese Aufgabe möchte ich programmieren.

The following iterative sequence is defined for the set of positive integers:

n → n/2 (n is even)
n → 3n + 1 (n is odd)

Using the rule above and starting with 13, we generate the following sequence:
13 → 40 → 20 → 10 → 5 → 16 → 8 → 4 → 2 → 1

It can be seen that this sequence (starting at 13 and finishing at 1) contains 10 terms. Although it has not been proved yet (Collatz Problem), it is thought that all starting numbers finish at 1.

Which starting number, under one million, produces the longest chain?

Hierzu habe ich folgenden Code erstellt.

[JAVA=42]public class Problem14 {

public static int folge2(int n){
int[]f=new int[n];

int i=1;
for(int n1=1; n1<=n; n1++){
int a=n1;
while(a!=1){
if(a%2==0){
a/=2;
i++;
}
else{
a=3*a+1;
i++;
}
if(a<n1){
i+=f[a-1]-1;
a=1;
}
}
f[n1-1]=i;
i=1;

}
int max=0;
int index=0;
for(int j=0; j<n; j++){
if(f[j]>max){
max=f[j];
index=j+1;
}
}
System.out.println("Die Zahl "+index+" produziert die laengste Kette von "+max);
return max;
}
public static void main(String[] args) {
long s=System.currentTimeMillis();
folge2(100000);
long f=System.currentTimeMillis();
long d=f-s;
System.out.println("Dauer: "+d);
}
}[/code]

Das Problem besteht darin dass in der Zeile 20, nämlich
Code:
i+=f[a-1]-1;
eine outofbound-Exception kommt und ich nicht weiß wieso. Das passiert übrigens nicht, wenn ich statt 1 Million nur die Zahlen bis 100000 einbeziehe.

Es würde mich echt sehr freuen, wenn ihr mir helfen könntet.
 

XHelp

Top Contributor
Dann solltest du debugausgaben einbauen um rauszufinden wieso das passiert. Da ja natürlich die Zeilennummer nicht stimmen brigt uns deine Zeilenangabe nicht viel
 
W

waaarun

Gast
Warum nicht rekursiv dieses Problem angehen?

Wird eine ungerade Zahl, die als int vorhanden ist, mit 3 multipliziert, so kann es zu einem Integer-Overflow kommen. -> AIOOBE

Java:
public static void met(int i, int j) {
    if (i == 1) {
        System.out.println(j);
    }

    if (i % 2 == 0) {
        met(i / 2    , j + 1);
    } else {
        met(3 * i + 1, j + 1); // Achtung
    }
}

j ist der Zähler. Muss dann noch entsprechend angepasst werden.
 

Dekker

Bekanntes Mitglied
Probiers mal mit long aus. Ich habe das gefühl das bei einem genügend großen Wert für a bei ungleicher größe etwas > integer.maxValue rauskommt. Da dann der Datenbereich zu klein ist und in Java alle Datentypen signed sind wird der Wert dann negativ.

Edit: Mist zu langsam.
 

Eiche89

Mitglied
@ waarun:

Rekursives angehen ist gut, habe ich auch erst gemacht, aber die Laufzeit ist leider viel zu lang (nach einer Stunde war noch nix da). Deshalb wollte ich versuchen, dass die Folge nicht für jede Zahl neu berechnet werden muss, sondern dass ich auf schon berechnetes im array zurückgreife.

@ Volvagia:

Du hast recht, ein negativer Index bei nem Array kann natürlich nicht klappen. Jetzt ist nur noch die Frage warum der negative Index überhaupt kommt.

Danke schonmal an euch
 

Dekker

Bekanntes Mitglied
Habe ich doch geschrieben...

Der größte mit int darstellbare positive Wert ist (2^31)-1. Dies kommt daher das alle Datentypen in Java signed sind. Wenn du nun eine Zahl hast die ungerade ist, kann es bei einem a das groß genug ist dazu kommen, dass a * 3 +1 > (2^31)-1 ist und damit das Ergebnis negativ wird.

Also änderst du jetzt alle ints durch long und es sollte laufen...
 

nrg

Top Contributor
du greifst einfach falsch auf den arrayindex zu. ich weiß auch nicht, was du da alles machst aber du brauchst doch nur eine schleife, die solange läuft, wie n != 1 (sowas macht man normal nicht, weil das natürlich in endlosschleifen enden kann aber hier ist das ja ein anderes thema) und in dieser schleife prüfen, ob n gerade ist oder nicht. wenn ja durch 2 teilen, ansonsten mal 3 + 1.

Hier mal ein kleines Beispiel:
Java:
public class CollatzProblem {

		public static void main(String[] args) {
			int max = 1, maxCount = 1;
			for (int i = 2; i <= 1000000; i++) {
				int curCount = getSequenceCount(i);
				if (curCount > maxCount) {
					maxCount = curCount;
					max = i;
				}
			}
			System.out.println("The longest chain with length " + maxCount + " produces " + max);
		}
		
		public static int getSequenceCount(long n) {
			int count = 0;
			while (n != 1) {
				n = n % 2 == 0 ? n / 2 : 3 * n + 1;
				count++;
			}
			return count;
		}
}

achte darauf, dass du für die berechnung keinen int nimmst. sonst wirst du afaik probleme bekommen.
 

Dekker

Bekanntes Mitglied
Was speicherst du den in F eigentlich? Die Zahl der Hops? Wäre es nicht einfach das in eine Variable zu schreiben und zu updaten wenn eine Zahl mehr Iterationen gebraucht hat anstatt immer noch mehr zu speichern und dann das maximum zu bestimmen?

Edit: Ja so wies nrg gemacht hat meinte ich das.
 
W

waaarun

Gast
Er will aber auf schon vorhanden Zwischenergebnisse zurückgreifen, und hier bietet es sich an, das ganze rekursiv zu formulieren. Oben fehlt übrigens das return in dem ersten if. Lest doch mal die Beiträge, bevor etwas gepostet wird :p

Es muss übrigens immer geprüft werden, ob kein Overflow stattfindet, weil nicht bewiesen ist, das für irgendeine Zahl <= 1 mil. keine Zahl >= 2^31 wird...
 
W

waaarun

Gast
Und, wenn ich long nehme, wäre das etwas anderes, als blind drauf zu vertrauen, dass es dann keinen Overflow gibt? Mein rekursiver Ansatz sieht jetzt übrigens so aus:

Java:
    public static int count(int i, HashMap<Integer, Integer> hm) {
        if (hm.containsKey(i)) {
            return hm.get(i);
        }

        int j;
        if (i % 2 == 0) {
            j = count(i / 2, hm) + 1;
        } else {
            j = count(3 * i + 1, hm) + 1;
        }
        hm.put(i, j);

        return j;
    }

    public static void main(String[] args) {
        HashMap<Integer, Integer> hm = new HashMap<Integer, Integer>();
        hm.put(1, 1);

        for (int i = 1; i < 21; i++) {
            System.out.println(i + ": " + count(i, hm));
        }
    }
 

Dekker

Bekanntes Mitglied
Und, wenn ich long nehme, wäre das etwas anderes, als blind drauf zu vertrauen, dass es dann keinen Overflow gibt? Mein rekursiver Ansatz sieht jetzt übrigens so aus:

Java:
    public static int count(int i, HashMap<Integer, Integer> hm) {
        if (hm.containsKey(i)) {
            return hm.get(i);
        }

        int j;
        if (i % 2 == 0) {
            j = count(i / 2, hm) + 1;
        } else {
            j = count(3 * i + 1, hm) + 1;
        }
        hm.put(i, j);

        return j;
    }

    public static void main(String[] args) {
        HashMap<Integer, Integer> hm = new HashMap<Integer, Integer>();
        hm.put(1, 1);

        for (int i = 1; i < 21; i++) {
            System.out.println(i + ": " + count(i, hm));
        }
    }

Na dann lass es jetzt mal mit größeren Zahlen als 21 laufen....
 

nrg

Top Contributor
ja ob rekursiv oder iterativ ist ja egal. wollte damit eigentlich nur an einem beispiel zeigen, dass der TO da etwas am ziel vorbeigeschossen ist

edit: achso. i ist ja nach wie vor ein int. na dann lass es doch mal mit der zahl 113383 laufen :)
 
W

waaarun

Gast
Na dann lass es jetzt mal mit größeren Zahlen als 21 laufen....

Die einzig vernünftige Lösung wäre BigInteger, wenn bis zur gewünschten Zahl noch niemand vorher getestet hat :p

Und es ich nicht so einfach, so etwas iterativ zu formulieren, wenn auf bereits berechnete Ergebnisse zurückgegriffen werden soll...:(
 
W

waaarun

Gast
Konnte nun auch mal testen, hier nochmal mit long und debug ausgabe:

Java:
public class Main {

    public static int count(long i, HashMap<Long, Integer> hm) {
        System.out.print(i + " ");

        if (hm.containsKey(i)) {
            return hm.get(i);
        }

        int j;
        if (i % 2 == 0) {
            j = count(i / 2, hm) + 1;
        } else {
            j = count(3 * i + 1, hm) + 1;
        }
        hm.put(i, j);

        return j;
    }

    public static void main(String[] args) {
        HashMap<Long, Integer> hm = new HashMap<Long, Integer>();
        hm.put(1L, 1);

        for (int i = 1; i < 21; i++) {
            System.out.println(" - " + i + ": " + count(i, hm));
        }

    }
}

Jetzt sieht man relativ schnell, dass auch für kleinere Werte viele der "Zwischenwerte" größer als der Ausgangswert werden können.
Aber, solange man es noch nicht ausprobiert hat, kann man auch nicht mit Sicherheit sagen, für welche Werte der Wertebereich des longs noch ausreichen wird und für welche nicht mehr. Wenn man Pech hat, gibt es einen Overflow, der nicht bemerkt wird, weil das Resultat immer noch ein positiver Wert ist.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A "Hello World"-Programm läuft nicht Java Basics - Anfänger-Themen 16
J Delay erzeugen, ohne Programm zu blockieren Java Basics - Anfänger-Themen 7
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
M Java Mail Programm Java Basics - Anfänger-Themen 4
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
M Mini Jar-Programm Java Basics - Anfänger-Themen 51
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
M Das Programm stellt nichts dar Java Basics - Anfänger-Themen 2
K Programm compilierbar aber nicht ausführbar... Java Basics - Anfänger-Themen 21
Z Programm Ideen Java Basics - Anfänger-Themen 8
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
T Programm stürzt ab Java Basics - Anfänger-Themen 40
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
N Programm Funktioniert mit .txt Datei aber nicht mit .rtf Datei Java Basics - Anfänger-Themen 2
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
Jul1n4tor Programm mit Scanner und If-Statements Java Basics - Anfänger-Themen 2
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
K Ist das Programm schlecht bzw. schlampig programmiert ? Java Basics - Anfänger-Themen 9
Zrebna Kann Java Programm nicht in Konsole ausführen Java Basics - Anfänger-Themen 1
K Warum läuft das Programm nicht(bzw. nicht richtig) Java Basics - Anfänger-Themen 4
M Von Eclipse zum richtigen Programm Java Basics - Anfänger-Themen 1
nbergmann IntelliJ: Wie lade ich ein fertiges Programm aus dem Lehrbuch? Java Basics - Anfänger-Themen 26
D Anfängerfrage zu meinem Programm. Java Basics - Anfänger-Themen 15
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 22
I Jetty starten von Programm (Main) Java Basics - Anfänger-Themen 27
Kydo Programm Beschreibung Java Basics - Anfänger-Themen 3
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 7
T Java FXML selbes Fenster verschiedene Stellen im Programm Java Basics - Anfänger-Themen 5
frager2345 Programm erstellen ohne Autoboxing und Unboxing Java Basics - Anfänger-Themen 13
D JAVA Programm schreiben Java Basics - Anfänger-Themen 46
P exportiertes Programm funktioniert nur teilweise Java Basics - Anfänger-Themen 7
J Mein Programm läuft bei der ersten Eingabe nicht mehr weiter, woran liegt das? Java Basics - Anfänger-Themen 6
M Wo hält das Programm an? Java Basics - Anfänger-Themen 11
J Mein Java Programm lässt sich nicht mehr bearbeiten Java Basics - Anfänger-Themen 2
Fugover Programm funktioniert nicht Java Basics - Anfänger-Themen 11
Fugover Kopfrechnen-Programm Java Basics - Anfänger-Themen 6
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
sserio Wieso funktioniert mein Programm nicht Java Basics - Anfänger-Themen 2
sserio Größtes Palindrom-Produkt Programm funktioniert nur halb Java Basics - Anfänger-Themen 23
J selbst erstellte Datei mit Programm öffnen Java Basics - Anfänger-Themen 10
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
A wie kann ich es in meinem Programm rein tun Java Basics - Anfänger-Themen 8
S Fehler beim Programm Java Basics - Anfänger-Themen 2
Jose05 Fehler im Programm feststellen Java Basics - Anfänger-Themen 2
F Kann mir jemand kurz dieses Programm erklären? Java Basics - Anfänger-Themen 22
I Programm erkennt nicht an das Array zurückgegeben wird trotz Initialisierung *einfach* Java Basics - Anfänger-Themen 9
J Nach dem Exportieren funktioniert mein Programm nicht mehr Java Basics - Anfänger-Themen 8
P Mein Programm wird zwar erfolgreich Compiliert, öffnet sich aber nicht Java Basics - Anfänger-Themen 6
J Kann ich mein Programm so schreiben? Java Basics - Anfänger-Themen 4
A Lotto Programm Java Basics - Anfänger-Themen 3
S Programm erstellen Java Basics - Anfänger-Themen 3
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
S MinMax Programm erstellen Java Basics - Anfänger-Themen 4
J Interpreter-Fehler Programm gibt nicht gewünschtes Ergebnis aus Java Basics - Anfänger-Themen 11
brypa Programm mit Eingabe Java Basics - Anfänger-Themen 129
B Java Programm soll mit Python kommunizeren Java Basics - Anfänger-Themen 1
SpigBin Programm läuft nicht weiter... Java Basics - Anfänger-Themen 10
M JAVA Programm in Website einbinden Java Basics - Anfänger-Themen 19
B Programm, dass alle 3 Tage eine Webseite öffnet? Java Basics - Anfänger-Themen 20
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
N Eclipse Programm normal ausführen Java Basics - Anfänger-Themen 1
D Programm auf Enter warten lassen Java Basics - Anfänger-Themen 2
C Programm das feststellen kann, ob eine eingegebene Zahl einem Schaltjahr entspricht, richtig geschrieben? Java Basics - Anfänger-Themen 11
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
WAB9703-04 Programm zum automatischen Ausfüllen von Formularen programmieren Java Basics - Anfänger-Themen 3
OSchriever Jar-Programm läuft auf Windows aber nicht auf Linux(Raspberri Pi4) Java Basics - Anfänger-Themen 22
G Programm Code Java Basics - Anfänger-Themen 5
CptK Achsenskalierung in Koordinatensystem hängt Programm auf Java Basics - Anfänger-Themen 5
H Kann eine while-Schleife ein Programm blockieren? Java Basics - Anfänger-Themen 8
TimoN11 Mail Programm mit Java? Java Basics - Anfänger-Themen 1
Sajeel Chattha Dieses Programm umschreiben Java Basics - Anfänger-Themen 5
J Programm beenden ohne System.exit() oder Runtime.exit() Java Basics - Anfänger-Themen 5
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
A Programm Histogram Java Basics - Anfänger-Themen 2
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
CT9288 Interaktion mit laufendem Programm -Fachbegriffe Java Basics - Anfänger-Themen 2
Gaudimagspam Assertions im Programm hinzufügen Java Basics - Anfänger-Themen 4
G Weiß jemand wie man dieses Programm schreibt? Java Basics - Anfänger-Themen 84
C Programm ausführen ohne JRE? Java Basics - Anfänger-Themen 3
justemii Gehalt berechnen - Aufgabe Java-Programm Java Basics - Anfänger-Themen 9
N Best Practice How can I creat a programm with java under windows 10 in order to open an spreadsheet in libreoffice calc format Java Basics - Anfänger-Themen 11
W Programm dass Palindrome erkennt Java Basics - Anfänger-Themen 6
K Erste Schritte Programm geht aus Schleife, warum? Java Basics - Anfänger-Themen 2
P Wie für EIN Java Programm von 64bit Java (=Standard) auf 32bit Java Installation (Windows) umschalten? Java Basics - Anfänger-Themen 6
K Programm stoppt einfach ohne Grund Java Basics - Anfänger-Themen 4
M Rekursives Programm zum Anzeigen von Primzahlen Java Basics - Anfänger-Themen 3
X Kurzes Java-Programm, das sich komisch verhält Java Basics - Anfänger-Themen 6
Zrebna Programm kann aus der Konsole nicht gestartet werden (in der IDE läuft es) Java Basics - Anfänger-Themen 2
K Error bei meinem Programm - Hilfe Java Basics - Anfänger-Themen 8
J Programm schreiben Java Basics - Anfänger-Themen 5
T Kann jemand kurz das Programm testen? Java Basics - Anfänger-Themen 13
T Programm Schleife/if Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben