Anonyme Klasse einer Liste erstellen

ocsme

Top Contributor
Hallo,

ich versuche eine Liste als Anonyme Klasse zu instanziieren doch das klappt leider nicht!
Wieso ich das machen möchte ist weil ich dann eine Aufgabe vereinfacht bekomme :D vielleicht erschwere ich mir das ganze auch wieder :p

Also hier erst einmal das was ich bis jetzt versucht habe.

Java:
List<T> a = new ArrayList<T>() {
                int k = 0;
                public void permute(int k) {
                     for(int i = k; i < data.size(); i++){
                            Collections.swap(data, i, k);
                            permute(k+1);
                            Collections.swap(data, k, i);
                        }
                        if (k == data.size() -1){
                            for(T s : data)
                                a.add((T) s.toString());
                            
                        }
                }
                permute(k);

            };

Leider verstehe ich nicht wie ich permute(k) richtig aufgerufen bekomme :(
Denn ich würde sehr gerne ein Array erstellen mit Permutationen. Die Daten kommen aus einem Array data. Sprich in data steht nun 1,2,3 drin dann sollte eben
1,2,3
1,3,2
2,1,3
...
raus kommen.
Doch leider verstehe ich nicht wie ich den Anfang mache damit permute sich überhaupt rührt :(

Vielleicht hat da jemand eine Idee :)

LG
 

httpdigest

Top Contributor
Hierfür könntest du z.B. einen Initializer Block nehmen:
Java:
public class Permutations<T> {
  @SuppressWarnings("serial")
  public static <T> List<List<T>> createPermutations(List<T> data) {
    return new ArrayList<List<T>>() {
      {
        permute(0);
      }
      private void permute(int k) {
        for (int i = k; i < data.size(); i++) {
          Collections.swap(data, i, k);
          permute(k + 1);
          Collections.swap(data, k, i);
        }
        if (k == data.size() - 1)
          add(new ArrayList<>(data));
      }
    };
  }
  public static void main(String[] args) {
    System.out.println(Permutations.createPermutations(Arrays.asList(1, 2, 3, 4)));
  }
}
 

ocsme

Top Contributor
Danke für die Antwort.
Leider klappt es so nicht bekomme NullPointerException.
Ich erkläre mal kurz die Aufgabe vielleicht mach ich wieder alles Falsch! :(

Aufgabenstellung:
Die Klasse Permutator<T> stellt für eine gegebene Collection von Elementen eines beliebigen Typs T einen Iterator über alle Permutationen der Elemente, die in der Collection enthalten sind zur Verfügung.

Aufgerufen wird sie so:

public static void main(String[] args) {
for(Collections<String> c : new Permutator<String> (asList(1,2,3,4)))
System.out.print(c) }
}

Außerdem steht für Ihre Implementierung die Klasse Permutations zur Verfügung:
class Permutations implements Iterable<Iterable<Integer>> {
private int size;
public Permutations(int size) { this.size = size; }
public Iterator<Iterable<Integer>> iterator() { ... }
}

Gesucht ist Methode iterator() der Klasse Permutator<T>

Ich dachte mir, da ich mit Permutations nichts anfangen konnte, das ich im Iterator einfach die Permutation erstelle und dann gleichzeitig drüber laufe :) doch das klappt leider nicht so ganz.

Code:
import java.util.*;

public class Permutator<T> {
    List<T> data;   
    Permutator() {
        
    }
    
    Permutator(List<T> t) {
        data = t;
    }

    public static void main(String[] args) {
        Permutator<String> test = new Permutator<String>(Arrays.asList("A","B","C","D"));
        
        Iterator i = test.iterator();
        while(i.hasNext())
            System.out.print(i.next()+" ");
    }

    
    public Iterator<Collection<T>> iterator() {
        return new Iterator<Collection<T>>() {
            int count = 0;
            List<T> a = new ArrayList<T>() {
                {
                    permute(0);
                }
                public void permute(int k) {
                     for(int i = k; i < data.size(); i++){
                            Collections.swap(data, i, k);
                            permute(k+1);
                            Collections.swap(data, k, i);
                        }
                        if (k == data.size() -1){
                            for(T s : data)
                                a.add((T) s.toString());
                        }
                }
            };
            
            @Override
            public boolean hasNext() {
                return count!=a.size()?true:false;
            }

            @Override
            public Collection<T> next() {
                List<T> tmp = new ArrayList<T>();
                if(hasNext()) {
                    tmp.add((T) a.get(count));
                    count++;
                }
                return tmp;
            }
            
        };
    
    }
}

LG
 

httpdigest

Top Contributor
Du scheinst leider überhaupt nicht verstanden zu haben, was überhaupt die Aufgabe sein soll. Dein Iterator soll nicht einelementige Collections liefern, sondern er soll die Collections liefern, die die Permutationen der ursprünglichen Collection/Liste sind. Und wieso fügst du `s.toString()` (also .toString()) der Liste hinzu? Wieso konvertierst du denn ein `T` immer zu seiner String-Repräsentation?
Desweiteren scheinst du leider überhaupt nicht meinen Code ausprobiert zu haben. Dort steht nicht `a.add(...)` sondern `add(...)`. Du willst add() auf dem `this` Objekt direkt aufrufen, und nicht erst eine äußere Variable (dein `a`) dereferenzieren, die noch gar nicht initialisiert ist.
 

httpdigest

Top Contributor
Und weil ich heute großzügig bin, hier eine mögliche Lösung (nach https://www.baeldung.com/java-array-permutations):
Java:
import java.util.*;
public class Permutator<T> implements Iterable<Collection<T>> {
  private final List<T> data;
  public Permutator(List<T> data) {
    this.data = data;
  }
  public Iterator<Collection<T>> iterator() {
    return new Iterator<Collection<T>>() {
      private final int[] indexes = new int[data.size()];
      private Collection<T> next = new ArrayList<>(data);
      private int i;
      private void advance() {
        while (next == null && i < data.size()) {
          if (indexes[i] < i) {
            Collections.swap(data, i % 2 == 0 ? 0 : indexes[i], i);
            next = new ArrayList<>(data);
            indexes[i]++;
            i = 0;
          } else {
            indexes[i] = 0;
            i++;
          }
        }
      }
      @Override
      public boolean hasNext() {
        return next != null;
      }
      @Override
      public Collection<T> next() {
        if (next == null)
          throw new NoSuchElementException();
        try {
          return next;
        } finally {
          next = null;
          advance();
        }
      }
    };
  }
  public static void main(String[] args) {
    for (Collection<String> permutation : new Permutator<String>(Arrays.asList("A", "B", "C", "D"))) {
      System.out.println(permutation);
    }
  }
}
 

ocsme

Top Contributor
Und weil ich heute großzügig bin, hier eine mögliche Lösung
Danke dafür finde ich super Nett :)
Werde es aber erst einmal weiter selbst Probieren.

Desweiteren scheinst du leider überhaupt nicht meinen Code ausprobiert zu haben.
Nein ausprobiert habe ich den Code nicht. Ich hab ihn überflogen und fand die Idee schon super GEIL mit dem Block also das hier:
{ Methode() }
Da dachte ich naja dann bekomme ich das auch alleine hin :p Falsch gedacht denn ich hatte ja nicht mehr im Kopf das die ArrayListe a so gesehen nicht existiert und dadurch auch nichts adden kann!

Du scheinst leider überhaupt nicht verstanden zu haben, was überhaupt die Aufgabe sein soll. Dein Iterator soll nicht einelementige Collections liefern, sondern er soll die Collections liefern, die die Permutationen der ursprünglichen Collection/Liste sind. Und wieso fügst du `s.toString()` (also .toString()) der Liste hinzu? Wieso konvertierst du denn ein `T` immer zu seiner String-Repräsentation?
Das alles habe ich deswegen so "hingebogen" weil meine ganze Klasse vorher anders aussah. Das ging an der Übungsaufgabe komplett vorbei aber es hat geklappt hier mal meine eigene Version von dieser Aufgabe:

Java:
import java.util.*;

public class Permutator<T> {
    
    List<T> data;
    ArrayList<T> permutation = new ArrayList<>();
    
    Permutator() {
        
    }
    
    Permutator(List<T> t) {
        data = t;
        permutation = makePermut(0);
    }
    
    public ArrayList<T> makePermut(int k){
        for(int i = k; i < data.size(); i++){
            Collections.swap(data, i, k);
            makePermut(k+1);
            Collections.swap(data, k, i);
        }
        if (k == data.size() -1){
            for(T s : data)
                permutation.add(s);
        }
        return permutation;
    }
    
    public static void main(String[] args) {
        Permutator<String> test = new Permutator<String>(Arrays.asList("A","B","C","D"));
        System.out.println(test);
        Iterator i = test.iterator();
        while(i.hasNext())
            System.out.print(i.next()+" ");
    }

    public Iterator<Collection<T>> iterator() {
        return new Iterator<Collection<T>>() {
            int count = 0;
            
            @Override
            public boolean hasNext() {
                return count!=permutation.size()?true:false;
            }

            @Override
            public Collection<T> next() {
                List<T> tmp = new ArrayList<T>();
                if(hasNext()) {
                    tmp.add((T) permutation.get(count));
                    count++;
                }
                return tmp;
            }
        };
    }
}


Erst so kam ich eben auf die Idee die Arbeit mit der Permutation (also das Array mit den Permutationen) im Iterator anzulegen :)

Danke nochmals :)

LG
 

ocsme

Top Contributor
So läuft es. Was mir gar nicht gefällt worüber ich mir jetzt aber auch nicht zwingenden den Kopf zerbrechen möchte ist die Ausgabe :D ich zähle den count dann einfach hoch das finde ich bei dir viel eleganter gelöst :)
Doch es hat letztlich auch bei mir geklappt :)

Nicht schön aber selten :D
Java:
    public static void main(String[] args) {
        Permutator<String> test = new Permutator<String>(Arrays.asList("A","B","C","D"));
        Iterator i = test.iterator();
        while(i.hasNext())
            System.out.println(i.next()+" ");
    }

    public Iterator<Collection<T>> iterator() {
        return new Iterator<Collection<T>>() {
            int count = 0;
           
            ArrayList<T> a = new ArrayList<T>() {
                       {
                        permute(0);
                      }
                      private void permute(int k) {
                        for (int i = k; i < data.size(); i++) {
                          Collections.swap(data, i, k);
                          permute(k + 1);
                          Collections.swap(data, k, i);
                        }
                        if (k == data.size() - 1)
                            for(T s:data)
                                add(s);
                      }
                    };

            @Override
            public boolean hasNext() {
                return count!=a.size()?true:false;
            }

            @Override
            public Collection<T> next() {
                List<T> tmp = new ArrayList<T>();
                if(hasNext()) {
                    tmp.add((T) a.get(count));
                    count++;
                }
                return tmp;
            }
        };
    }

Bei der Ausgabe habe ich halt immer für 1 Element 1 Array :D wollte es so machen:D
Java:
@Override
            public Collection<T> next() {
                List<T> tmp = new ArrayList<T>();
                if(hasNext()) {
                    tmp.add((T) a.get(count++));
                    tmp.add((T) a.get(count++));
                    tmp.add((T) a.get(count++));
                    tmp.add((T) a.get(count));

                    count++;
                }
                return tmp;
            }
Das passt natürlich dann nur für 4 Elemente sind es weniger oder mehr sollte das nicht funktionieren :D
 

ocsme

Top Contributor
Die Ausgabe mal ganz naiv runter gecodet:
Wie schon gesagt lange nicht so schön wie bei @httpdigest

Java:
@Override
            public Collection<T> next() {
                List<T> tmp = new ArrayList<T>();
//                if(hasNext()) {
//                    tmp.add((T) a.get(count));
//                    count++;
//                }
                if(hasNext()) {
                    int i = 0;
                    while(i != data.size()) {
                        tmp.add( (T) a.get(count));
                        i++;
                        count++;
                    }
                }
                
                return tmp;
            }
        };
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Klassen Anonyme innere Klasse Java Basics - Anfänger-Themen 4
M Anonyme Klasse und lokale Variable Java Basics - Anfänger-Themen 2
J Anonyme Klasse Java Basics - Anfänger-Themen 5
J List als anonyme Klasse Java Basics - Anfänger-Themen 9
G static Klasse / anonyme Klasse Java Basics - Anfänger-Themen 4
D Unterschied innere Klasse/ anonyme innere Klasse Java Basics - Anfänger-Themen 7
M Anonyme Klassen - Warum wird in der Konsole nichts ausgegeben? Java Basics - Anfänger-Themen 1
W Abarbeitungsreihenfolge Anonyme Klassen Java Basics - Anfänger-Themen 2
L Anonyme Methode in einer ForEach-Schleife Java Basics - Anfänger-Themen 2
M anonyme nicht-lokale Klassen Java Basics - Anfänger-Themen 13
J Wozu werden die anonyme Klassen verwendet? Java Basics - Anfänger-Themen 9
C Anonyme Objekte und mehr Java Basics - Anfänger-Themen 46
B Anonyme Klassen Java Basics - Anfänger-Themen 5
I @Inject in normaler Klasse? Java Basics - Anfänger-Themen 4
P Enum oder normale Klasse? Java Basics - Anfänger-Themen 10
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
P Wie kann ich meine Keylistener Klasse unterscheiden lassen, von welcher "Quelle" der Input kommt? Java Basics - Anfänger-Themen 2
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Amina556 Eigene Klasse definieren Java Basics - Anfänger-Themen 9
berserkerdq2 Intelij, wie kann ich einstellen, dass die aktuelle Klasse ausgeführt wird, wenn ich aufs Startsymbol drücke, gibts da eine Tastenkombination? Java Basics - Anfänger-Themen 11
M Klasse in Runden Klammern bei Objektimplementierung Java Basics - Anfänger-Themen 4
J Klassen Klasse als Komponententyp bei Feldern Java Basics - Anfänger-Themen 2
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
Detlef Bosau nichtstatische Innere Klasse, this Pointer. Java Basics - Anfänger-Themen 47
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
J Zugriff auf eine 2. Klasse die per UI-Designer erstellt wurde Java Basics - Anfänger-Themen 1
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
B Klasse statisch erstellen da n-mal geladen Java Basics - Anfänger-Themen 3
T Meine Klasse wird nicht gefunden Java Basics - Anfänger-Themen 1
XWing Random Punkte erstellen mit der Random klasse Java Basics - Anfänger-Themen 15
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
frager2345 Optional Klasse Java Java Basics - Anfänger-Themen 2
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
H Klassen Typ und Intitialisierungs-Klasse, wer bestimmt was? Java Basics - Anfänger-Themen 1
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
T Thread beenden aus zweiter Klasse Java Basics - Anfänger-Themen 4
frager2345 Java Klasse Buch verwalten Java Basics - Anfänger-Themen 0
frager2345 Java eigen Klasse zum verwalten von Büchern Java Basics - Anfänger-Themen 3
T Zugriff auf Control anderer Klasse Java Basics - Anfänger-Themen 5
H Compiler-Fehler Klasse in einem Package wird nicht gefunden bzw. akzeptiert Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
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
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
C Int an andere Klasse übergeben Java Basics - Anfänger-Themen 26
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
B Klasse "Character" Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
U Warum kann ich, auf private Variablen zugreifen, wenn ich ein Objekt in der Klasse, die private Variablen hat erstelle und dort drauf zugreifen will? Java Basics - Anfänger-Themen 7
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
D Array in Main Methode aus anderer Klasse aufrufen Java Basics - Anfänger-Themen 3
I Array Länge in Klasse festlegen Java Basics - Anfänger-Themen 1
L Klassen Vektor Klasse Java Basics - Anfänger-Themen 2
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
M Wie kann ich eine Methode aus einem Interface in eine Klasse implementieren, so dass sie ihre Funktion ausführt? Java Basics - Anfänger-Themen 7
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
W Klasse existiert prüfen Java Basics - Anfänger-Themen 5
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
J Fehler bei array aus anderer Klasse Java Basics - Anfänger-Themen 3
D Einen boolischen Wert aus einer Methode in einer anderen Klasse aufrufen? Java Basics - Anfänger-Themen 11
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
R TreeSet Zugriff aus anderer Klasse Java Basics - Anfänger-Themen 8
C Auf die Methode einer anderen Klasse zugreifen Java Basics - Anfänger-Themen 1
B Static Attribute in einer Klasse, wie geht das? :O Java Basics - Anfänger-Themen 19
M Von einem Menü Methode aus anderer Klasse ausführen, die errechnete Werte in Datei schreibt. Java Basics - Anfänger-Themen 8
KogoroMori21 Objektvariable anderer Klasse übernehmen, Getter/Setter Java Basics - Anfänger-Themen 11
Vivien Auf eine Variable von einer anderen Klasse aus zugreifen Java Basics - Anfänger-Themen 3
M Aufruf von statischen Methoden einer anderen Klasse Java Basics - Anfänger-Themen 15
tony241188 Implementieren Sie die Klasse Hersteller, welche die folgenden Elektrogeräte produziert Java Basics - Anfänger-Themen 3
J Junit4 Klasse erstellen Java Basics - Anfänger-Themen 5
T Auf Instanz der selben Klasse aus überschriebener Methode in Methode zugreifen. Java Basics - Anfänger-Themen 2
M Scanner Klasse Java Basics - Anfänger-Themen 4
L Meine erste eigene Exception Klasse Java Basics - Anfänger-Themen 10
E Warum lässt sich eine Klasse nicht starten, wenn eine andere Klasse in dem Modul fehlerhaft ist? Java Basics - Anfänger-Themen 1
CptK Vererbung Attributtyp in Super-Klasse noch nicht festlegen Java Basics - Anfänger-Themen 1
P Wie rufe ich Methoden mit einer Referenz auf eine Klasse||Objekt auf Java Basics - Anfänger-Themen 4
I JaxB und Klasse "Object" ? Java Basics - Anfänger-Themen 7
H Quellcode Scanner Klasse Java Basics - Anfänger-Themen 2
L Attribute aus Klasse in berechnungs Methode übergeben Java Basics - Anfänger-Themen 1
A Klasse Menge mit Objekten der Klasse Person Java Basics - Anfänger-Themen 8
C Meldung einer Klasse nach "oben" Java Basics - Anfänger-Themen 6
A Methode in einer anderen Klasse verwenden Java Basics - Anfänger-Themen 1
D Attribut Telefonnummer - eigene Klasse oder String Java Basics - Anfänger-Themen 13
N Variable aus anderen Variablen in statischer Klasse berechnen/abspeichern? Java Basics - Anfänger-Themen 4
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
L Datentypen Deklarierte Felder einer Generic Klasse bestimmen Java Basics - Anfänger-Themen 7
C Methoden können nicht auf Instanzvariable der Klasse zugreifen Java Basics - Anfänger-Themen 3
J Scanner-Klasse Java Basics - Anfänger-Themen 2
itsmejo Erste Schritte Auf Attribut einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 14
P NoClassDefFoundError: org/apache/commons/collections4/ListValuedMap trotz vorhandener Klasse? Java Basics - Anfänger-Themen 10
V Array aus Klasse um vererbte Elemente erweitern Java Basics - Anfänger-Themen 3
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben