Array-Index nur als Integer möglich?

Status
Nicht offen für weitere Antworten.

Jan A

Mitglied
Hallo Java-Programmierer,

ich bin ein totaler Anfänger in Java und stehe jetzt vor einem Problem:
Ich habe ein Programm geschrieben, welches Primzahlen bis zur vorgegebenen Höhe mit
dem Sieb des Erathosthenes berechnet. Dabei wird mit einem eindimensionalen Array gearbeitet, in dem die Zahlen gestrichen werden. Wenn ich aber Primzahlen höher als 46348 ausrechnen möchte, kommt immer diese Fehlermeldung:
Code:
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: -2146737495
Unter 46347 funktioniert aber alles. Wer den Fehler selber sehen möchte, kann sich hier das JAR-
Archiv herunterladen: http://intech.in.funpic.de/java/primzahlen/primzahlen.zip
Parameter:





-w Primzahlen in Textdatei schreiben

-m Höchste Primzahl
-s Textdatei

-s Primzahlen anzeigen
-m Höchste Primzahl

-c Prüfen, ob Zahl Prim
-m Zu prüfende Zahl

Neben dem Java-Archiv ist der Quellcode mit im ZIP.
Ich dachte schon, dass die Integerbegrenzung mir in die Quere kommt, und habe versucht, einen long als Array-Index festzulegen. Da meckert dann aber der Compiler, int ist benötigt und long gefunden. Ich hoffe ihr könnt mir weiterhelfen,

MfG Jan
 

Wildcard

Top Contributor
int geht deutlich höher als 46000. Wie dir die Fehlermeldung zu sagen versucht, übergibst du auch keine 46348, sondern -2146737495. Du wirst also irgendeinen seltsamen Fehler im Code haben. Nimmst du den Index vielleicht zum Quadrat?
 
S

SlaterB

Gast
genau, und 46348^2 ist höher als der maximale int-Wert,

der ist 2147483647, 2.1 Milliarden, das sollte genug sein für alle Arrays, die in der Länge mindestens 8 GB groß sind ;)
 

Jan A

Mitglied
Das ist richtig, die Integervariable mit der höchsten zu errechnenden Primzahl wird quadriert, da alle Vielfachen der aktuellen Zahl mit i*i beginnend als false im Array markiert werden. Also wird bei 46348^2 die Integergrenze überschritten. Könnte man Arrays mit einem Long definieren würde das erstmal nicht passieren, oder?
Trotzdem: Könnte man nicht ein 2D-Array erstellen mit zweimal 46347 und alles über 46347 im ersten werden dann zum zweiten umgeleitet?
Also so:
Code:
int[][] array= new int[5][5];


array[0][1]=1;
array[1][1]=2;
array[2][1]=3;
array[3][1]=4;
array[4][1]=5;

array[0][2]=6
array[1][2]=7;
array[2][2]=8;
array[3][2]=9;
array[4][2]=10;

array[0][3]=11;
array[1][3]=12;
array[2][3]=13;
array[3][3]=14;
array[4][3]=15;
Wenn die Zahlen dann jew. "umgeleitet" werden, kostet dass bestimmt extrem
viel Zeit oder?


Jan
 
S

SlaterB

Gast
was du willst ist immer noch unklar,
aber nur zur Wiederholung: ein Array der Länge 46348^2 belegt 8 GB Arbeitsspeicher (!),
das ist mehr als jedes Betriebssystem braucht und meisten PCs überhaupt haben

was um alles in der Welt kann dein kleines Programm damit nur machen?
 

0x7F800000

Top Contributor
Da scheint jemand einen sehr fortgeschrittenen sieb des eratosthenes zu programmieren. Die neue version von Jan A ist nicht nur in der lage festzustellen, ob eine Zahl prim (=ja=1=true) oder nicht prim (=nein=0=false) ist, sondern auch noch 31 weitere wichtige eigenschaften der Zahl als nebenprodukt auszurechnen ;) Daher braucht's entsprechend viel platz ;)

so, und wenn du mit der korrektur des ersten malheurs fertig bist, siehst du dir bei der Wikipedia diese zeile nochmal genauer an:
Wikipedia hat gesagt.:
Sobald das Quadrat der Primzahl größer als die Schranke S ist, sind alle Primzahlen kleiner oder gleich S bestimmt

und den quadrat rechnest du bitte auch nicht zig tausend mal neu aus, okay? ;)
 

Jan A

Mitglied
Andrey hat gesagt.:
Da scheint jemand einen sehr fortgeschrittenen sieb des eratosthenes zu programmieren. Die neue version von Jan A ist nicht nur in der lage festzustellen, ob eine Zahl prim (=ja=1=true) oder nicht prim (=nein=0=false) ist, sondern auch noch 31 weitere wichtige eigenschaften der Zahl als nebenprodukt auszurechnen ;) Daher braucht's entsprechend viel platz ;)

Die Zahl 46347^2 tritt doch alleine deshalb schon auf, da der erste Schritt, wenn eine Zahl prim ist, das Quadrat derselben im Array als false=nicht prim zu setzen, ist.


Also um das mal klarzustelllen: Mit AutoIT ging das ohne Probleme! Und zwar mit 1GB Arbeitsspeicher und nach demselben Prinzip

Edit: Also nicht bis 46347^2, aber bis 1000000 bestimmt


Jan
 

0x7F800000

Top Contributor
Da wir hier ja keinerlei code zu sehen bekamen, sagt uns das leider nicht viel ;) Aber wenn's funktioniert: gut :toll:
was dauert's denn in etwa, bis du mit der methode die größtmögliche int-Primzahl ausgerechnet hast?
 

0x7F800000

Top Contributor
Bis 2.5 Millionen etwa in größenordnung einer sekunde? naja, Integer.MAX_VALUE ist irgendwas deutlich über 2 Milliarden, dann wird das doch bisschen dauern, da kann man schon eine runde Kaffee trinken gehen ;)

Das kann man womöglich auch irgendwie geschickt auf mehrere threads aufteilen, dass die sich nicht gegenseitig zerfleischen... mich würd mal brennend interessieren, ob das bei multicore prozessoren was bringt. ???:L
ich brobiere das mal aus, wenn ich nix besseres zu tun hab :p
 

Jan A

Mitglied
Komisch, über 3 Millionen komm ich nicht drüber wech. :?
Fehler:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at primzahlenberechnung.Erathosthenes.showPrims(Erathosthenes.java:85)
at primzahlenberechnung.Main.main(Main.java:60)



Muss ma n bisschen googlen


Edit: Habs raus= Heap vergrößern!
Dann kriege ich 50 Millionen in zwei Sekunden.
Aber größer als 1GB krieg ich den Heap nicht. Man müsste mal das Programm so ändern,
dass es die Festplatte als "Arbeitsspeicher" nutzt. Wäre wahrscheinlich 20 mal langsamer,
aber man könnte ja fast unendlich lange rechnen.
Würde man zwei Wochen im Arbeitsspeicher lang durchrechnen, käme man bis 20 Billionen, und einer Speichernutzung von sage und schreibe 12 Terabyte.
Mit Festplatte käme man also bis 500 Milliarden, und einer Größe von 300 Gigabyte. Irgendwie kommt mir das sehr wenig vor
:D

Jan
 

Jan A

Mitglied
Andrey hat gesagt.:
Das kann man womöglich auch irgendwie geschickt auf mehrere threads aufteilen, dass die sich nicht gegenseitig zerfleischen... mich würd mal brennend interessieren, ob das bei multicore prozessoren was bringt. ???:L
ich brobiere das mal aus, wenn ich nix besseres zu tun hab :p

Ich glaube, mit dem Sieb des Erathosthenes geht das nicht., da man immer bei 2 anfängt, und letztendlich die Threads genau dasselbe tun. Man könnte das mal mit dem Sieb des Atkin versuchen, denn da kann man vorgeben, von welcher Zahl begonnen werden soll. Dann könntest du ja den einen Thread bis 1 Milliarde und den zweiten bis zu zwei Milliarden rechnen lassen.

Jan
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
M Ersten Index von Array bestimmen Java Basics - Anfänger-Themen 14
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
G Methoden Methode die aus einem Array ein Index ausgibt? Java Basics - Anfänger-Themen 2
M Index of Array erweiteren Java Basics - Anfänger-Themen 24
L gerader Index im Array Java Basics - Anfänger-Themen 8
Z Array-Index einmalig je mit Random füllen Java Basics - Anfänger-Themen 7
M Kleinsten Index in Array finden Java Basics - Anfänger-Themen 6
E Arrayeintrag nach Index löschen und Array kürzen Java Basics - Anfänger-Themen 3
S Array - index von Benutzer eingegebenen char ausgeben Java Basics - Anfänger-Themen 3
MiMa Array mit ungültigen Index ansprechen Java Basics - Anfänger-Themen 2
F Fehler bei Array und Index Programmierung Java Basics - Anfänger-Themen 18
T Erste Schritte Java ein Array Feld[index] zurueckgeben? Java Basics - Anfänger-Themen 20
E Array bei Index ändern Java Basics - Anfänger-Themen 14
A dynamisches Array - Index Liste Java Basics - Anfänger-Themen 2
X Array Index Out of Bounds Java Basics - Anfänger-Themen 39
S Array bei index halbe umdrehen ohne hilfsfeld Java Basics - Anfänger-Themen 13
B Array mit Index 1 starten lassen Java Basics - Anfänger-Themen 5
P Array index per char suche auslesen Java Basics - Anfänger-Themen 3
H RemoteSocketAddress als Index von einem Array Java Basics - Anfänger-Themen 10
J Array - Index ermitteln per Wert Java Basics - Anfänger-Themen 3
E Array Index out of Bound Java Basics - Anfänger-Themen 5
E array index an methode übergeben? Java Basics - Anfänger-Themen 6
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben