Collections Arrays in ArrayList abspeichern

dbrust_2000

Mitglied
Ich habe folgendes Problem. Ich möcht int-Arrays in einer ArrayList abspeichern. In einer Testklasse habe ich folgendes probiert. und das geht auch:
Java:
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class JavaArrayListOfStringArray {

    public static void main(String[] args) {
        // List of String arrays
        ArrayList<int[]> list = new ArrayList<int[]>();
       
        int[] arr1 = new int[3];
        int[] arr2 = new int[4];
        arr2[0]=1;arr2[1]=2;arr2[2]=3;arr2[3]=4;
        arr1[0]=1;arr1[1]=2;arr1[2]=5;
        list.add(arr1);
        list.add(arr2);
        // printing list of String arrays in the ArrayList
        for (int[] strArr : list) {
            System.out.println(Arrays.toString(strArr));
        }
    }

}

Nun habe ich das nDamenProblem implementiert und ich möchte halt alle Lösungen (die habe ich als Array angelegt) in einer ArrayList speichern. Aber wenn ich das so mache wie oben, legt er zwar die Arrays an, die sind aber nicht gefüllt.

Java:
import java.util.*;



public class NDamenProblem
{
    private int m[]; //meine Loesung
    private int n; // Dimension des Problems
    private int anz; //Anzahl der Loesungen
    //private List<String> speicher; //damit geht es, aber
    private ArrayList<int[]> speicher;// ich möchte es so machen
    public NDamenProblem(int n){
        //m = new int [4];
        this.n=n;
        //speicher = new List<String>();
        speicher = new ArrayList<int[]>(); //speicher initialisiert!
        m=new int [n];
        Arrays.fill(m,0);
        anz = 0;
    }

    public void behandleKnoten(){
        behandleKnoten(0);
        System.out.println("Lösungen: " + anz);
    }

    private void behandleKnoten(int ebene){
        if (ebene == n){ 
            anz++;
            //System.out.println(anz+". Lösung: "+ Arrays.toString(m)); //Das geht! in m stehen wirklich Werte>0
            //speicher.append(Arrays.toString(m)); // Das geht auch
            speicher.add(m); //aber hier hat m nur die Werte 0!!!
        }
        else{
            for(int j = 1; j<n+1;j++){ 
                if(pruefe(j,m,ebene)){
                    m[ebene]=j;
                    behandleKnoten(ebene+1);
                }
            }
            m[ebene]=0;
        }
    }

    private boolean pruefe(int zahl, int[] a, int ebene){

        for (int i = 0;i<ebene;i++){
            //schaue, in die Spalte
            if (zahl == a[i]){
                return false;
            }
            // Schaue in die Diagonalen
            if(zahl == a[ebene-i-1]+1+i || zahl == a[ebene-i-1]-1-i ){
                return false;
            }
        }

        return true;
    }

    /*
    public List<String> getSpeicher(){
    return this.speicher;
    }*/

    public ArrayList<int[]> getSpeicher(){
        return this.speicher;
    }

    //End GetterSetterExtension Source Code
    //!
}
 

dbrust_2000

Mitglied
Noch ne main-Methode zum Testen
Java:
    public static void main(String[] args) {
        NDamenProblem ndp = new NDamenProblem(4);
        ndp.behandleKnoten();
        int[] arr1 = ndp.getSpeicher().get(0);
        int[] arr2 = ndp.getSpeicher().get(1);
        
        System.out.println(Arrays.toString(arr1));
        System.out.println(Arrays.toString(arr2));
    }
 

Kirby.exe

Top Contributor
Naja deine Arrays.fill() Methode bekommt eine 0 übergeben, somit ändert es nichts am Array ;) Da int ein primitiver Datentyp ist, wird das Array an allen Stellen mit 0 initialisiert :) Probiere mal Arrays.fill(m,1);
 

temi

Top Contributor
Naja deine Arrays.fill() Methode bekommt eine 0 übergeben, somit ändert es nichts am Array
Das ist nicht das Problem. Der Inhalt von "m" wird ja später in der rekursiven Methode geändert.

Wenn diese Stelle zum ersten Mal aufgerufen wird, dann enthält m tatsächlich Werte ungleich 0. Du fügst der ArrayListe danach eine Referenz auf dieses m hinzu.

Allerdings wird durch die rekursiven Aufrufe danach der else-Zweig noch einigemal durchlaufen. Du arbeitest allerdings immer auf dem selben "m". Damit werden auch die Werte des bereits in der Arrayliste enthaltenen "m" verändert. Es ist ja eine Referenz auf das eine "m" das es gibt.

Ich habe keine Ahnung was dein Code genau macht, aber versuche mal der ArrayListe eine neue Kopie von "m" zu übergeben (Arrays.copyOf()). Dann werden in der Liste Referenzen auf verschiedene Arrays gespeichert.

Hier noch mal zur Verdeutlichung:
Java:
public static void main(String[] args) {

    int[] m = new int[4];

    ArrayList<int[]> list = new ArrayList<>();

    list.add(m); // Liste bekommt eine Referenz auf das Array m übergeben.

    m[0] = 42;

    // Beide Referenzen zeigen auf das selbe Array
    // deshalb wirkt sich jede Änderung an einem der "beiden" Arrays
    // auch auf das "andere" Array aus (es gibt ja nur EIN Array)
    System.out.println(Arrays.toString(m));
    System.out.println(Arrays.toString(list.get(0)));

    list.get(0)[1] = 1;

    System.out.println(Arrays.toString(m));
    System.out.println(Arrays.toString(list.get(0)));

}
Ausgabe
Code:
[42, 0, 0, 0]
[42, 0, 0, 0]
[42, 1, 0, 0]
[42, 1, 0, 0]
 
Zuletzt bearbeitet:

dbrust_2000

Mitglied
Hi Temi,
aber versuche mal der ArrayListe eine neue Kopie von "m" zu übergeben (Arrays.copyOf())
Das klappt! Vielen Dank.

Und eigentlich habe ich es auch verstanden, trotzdem wundere ich mich ein wenig, dass das bei Strings funktioniert. Da werden doch auch Referenzen übergeben, oder habe ich da etwas nicht kapiert?

Liebe Grüße

Daniel
 
K

kneitzel

Gast
Strings sind unmutable, d.h. eine Referenz auf einen String wird immer auf den gleichen String verweisen. Bei einer Veränderung wird ein neuer String erstellt und Du bekommst somit ständig neue Referenzen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
3 ArrayList Integer Wrapper Klasse als Ersatz für normale Arrays Java Basics - Anfänger-Themen 10
F Aufgabe Arrays in ArrayList Java Basics - Anfänger-Themen 8
N Zugriff auf Werte in Arrays innerhalb ArrayList Java Basics - Anfänger-Themen 2
M Datentypen java.util.Arrays$ArrayList cannot be cast to [Ljava.lang.String; Java Basics - Anfänger-Themen 11
N Ausgabe des Inhalts eines String Arrays in einer ArrayList Java Basics - Anfänger-Themen 4
M Arrays und ArrayList Java Basics - Anfänger-Themen 3
G Arraylist mit Arrays belegen Java Basics - Anfänger-Themen 3
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
A Java.util.Arrays Java Basics - Anfänger-Themen 15
T Methodenverknüpfung mit Arrays Java Basics - Anfänger-Themen 4
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
F Eine Zahl mit Arrays vergleichen Java Basics - Anfänger-Themen 7
A 2d Arrays aus txt.file einlesen Java Basics - Anfänger-Themen 16
B Arrays Java Basics - Anfänger-Themen 4
P Arrays "automatisch" erstellen lassen Java Basics - Anfänger-Themen 12
B Nur eine bestimmte Anzahl an Arrays ausgeben Java Basics - Anfänger-Themen 9
H Gemeinsame Schnittmenge zweier Arrays ausgeben Java Basics - Anfänger-Themen 12
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben