Probleme mit ArrayList

Status
Nicht offen für weitere Antworten.

andreas2505

Bekanntes Mitglied
Hallo,

ich habe folgendes Programm.
Mit diesem will ich zahlen in eine Liste schreiben und nach dem Prinzip von eratosthenes rausfinden, ob die gesuchte Zahl eine Primzahl ist.

Allerdings tritt deim Eingeben irgendeiner Zahl folgender Fehler auf:

Java:
java.lang.IndexOutOfBoundsException: Index: 56, Size: 54
	at java.util.ArrayList.RangeCheck(ArrayList.java:547)
	at java.util.ArrayList.remove(ArrayList.java:387)
	at SiebdesEratosthenes2.isPrime(SiebdesEratosthenes2.java:38)


Programm:

Java:
import java.util.*;


public class SiebdesEratosthenes2
{
    

    public SiebdesEratosthenes2()
    {    
    }
    
    
    
    private static long abrunden(double n) {
        return Math.round(n);
    }
    
    
    private static boolean inListe(ArrayList liste, long n) {
        if (liste.contains(n)) return true;
        return false;
    }
    
    
    public static boolean isPrime(long n) {
        ArrayList zahlen = new ArrayList();
        for (long z=2; z<=n+1; z++) {
            zahlen.add(z);
        }
        for (int i=2; i<=abrunden(Math.sqrt(n)); i++) {
            if (zahlen.get(i) != null) {   
                for (int k=i; k<=abrunden(n/i); i++) {
                    zahlen.remove(k*i);
                }
            }
        }
        return inListe(zahlen, n);
    }
    
    
    
}

wo liegt der Fehler?
 
S

SlaterB

Gast
wenn du aus der ArrayList ein Element löschst, dann rücken alle anderen eine Position auf,
wahrscheinlich musst du
set(k*i,null);
statt
remove(k*i);
aufrufen,

oder verwende ein Array, da ist das leichter zu erkennen, da wird nix verrückt (im Sinne von verrücken),
die Anzahl Elemente kennst du ja vorher auch

edit:
oder du hast versehentlich die obige dieser beiden Methoden verwendet:
Java:
 E 	remove(int index)
          Removes the element at the specified position in this list.
 boolean 	remove(Object o)
          Removes the first occurrence of the specified element 
          from this list, if it is present.
dann musst du in diesem Fall den int manuell in einen Integer umwandeln
 
Zuletzt bearbeitet von einem Moderator:

andreas2505

Bekanntes Mitglied
also hab mal versucht mit set, aber da kommt auch der fehler, bloß mit gleichem wert, also:

Java:
java.lang.IndexOutOfBoundsException: Index: 64, Size: 64
	at java.util.ArrayList.RangeCheck(ArrayList.java:547)
	at java.util.ArrayList.set(ArrayList.java:337)
	at SiebdesEratosthenes2.isPrime(SiebdesEratosthenes2.java:38)

was könnte jetzt noch falsch sein?
 
S

SlaterB

Gast
siehe edit im ersten Posting ;)

und noch ein edit:
> if (zahlen.get(i) != null) {
ist dann aber etwas seltsam, vielleicht doch besser Array und außer noch prüfen, ob außerhalb der Array-Grenzen
 

andreas2505

Bekanntes Mitglied
und wie genau muss ich das machen.
Es muss es ja als Object erkennen, aber wenn ich nen int eingebe mit neew Integer oder so hab ich ja dasselbe Problem
 
S

SlaterB

Gast
welches Problem mit welcher Exception bei welchen Code?
remove(new Integer()) kann doch kaum zu einer IndexOutOfBoundsException führen oder bei welchem Vorschlag bist du gerade
 

andreas2505

Bekanntes Mitglied
ok, klappt. Hatte was verwechselt.

Andere Frage: Ich habe es extra mit einer ArrayList gemacht, weil ich damit mehr Zahlen in die ArrayList aufnehmen kann. Aber wenn ich jetzt eine zu große Zahl eingebe, kommt wieder die Fehlermeldung, dass es größer als int ist. Aber eigentlich habe ich doch überall long genommen, oder?

hängt das mit den laufvariablen in den schleifen zusammen?
Aber wie könnte ich die ändern?
 
Zuletzt bearbeitet:
S

SlaterB

Gast
in eine ArrayList passen nur soviele Zahlen wie in ein Array, Integer.MAX_VALUE
 

andreas2505

Bekanntes Mitglied
kann ich denn dann eine normale list nehmen, oder was würdest du empfehlen, weil eigentlich soll es für unendlich viele/große werte gehen
 
S

SlaterB

Gast
LinkedList geht, kann aber sehr langsam werden wenn man die öfters durchlaufen muss, z.B. für die remove-Methode,
oder besser eine Menge von Arrays,
jedes davon mit Integer.MAX_VALUE erfordert eh 2 GB Arbeitsspeicher, wenn du also mehr als 2-3 hinbekommst, dann ist das schon ein Wunder ;)

in der Theorie kann man jedenfalls bei mehreren Arrays zu einem long-Index leicht das passende Array und den Index darin berechen, / und % Integer.MAX_VALUE
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
L If Anweisung mit ArrayList Probleme Java Basics - Anfänger-Themen 6
R Probleme mit ArrayList Java Basics - Anfänger-Themen 6
A Probleme mit Arraylist Java Basics - Anfänger-Themen 14
S ArrayList probleme Java Basics - Anfänger-Themen 4
S Probleme mit ArrayList Java Basics - Anfänger-Themen 6
B ArrayList-Probleme Java Basics - Anfänger-Themen 3
F Probleme mit Array bzw. ArrayList Java Basics - Anfänger-Themen 26
T Probleme mit ArrayList, in der Objekte gespeichert sind, die ArrayLists enthalten Java Basics - Anfänger-Themen 2
I Probleme beim adden von Elementen in einer ArrayList Java Basics - Anfänger-Themen 10
J Probleme mit Collection ArrayList Java Basics - Anfänger-Themen 2
N Probleme mit ArrayList Java Basics - Anfänger-Themen 9
V Arraylist Probleme Java Basics - Anfänger-Themen 4
N Probleme mit ArrayList Java Basics - Anfänger-Themen 9
D Probleme bei Verwendung short und int im Constuctor Java Basics - Anfänger-Themen 6
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12

Ähnliche Java Themen


Oben