Argh: hab ArrayList von ArrayLists, Konstruktor will ArrayLists

Status
Nicht offen für weitere Antworten.

Frollein

Mitglied
Hey,

übersetze gerade ein Projekt von mir von Python in Java und bin stinksauer auf letztere...! Gut gut, ich hab auch nicht allzuviel Ahnung von Java, aber merk doch immer wieder was es alles nicht gibt... In Python gibts ne Methode für das Kreuzprodukt von Listeneinträgen; hab für Java hier eine nette Klasse gefunden, die eigentlich tut was ich will.

Ich poste die mal... (wenn ich irgendein Copyright verlezte - schlagt mich.)
Java:
/***
 * Copyright (c) 2008 Adam Pingel
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 */

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.NoSuchElementException;

public class CrossProduct<E> implements Iterable<List<E>>
{
	private List<Iterable<E>> iterables = new ArrayList<Iterable<E>>();

    public CrossProduct(List<? extends Iterable<E>> iterables)
    {
        this.iterables.addAll(iterables);
    }
    
	public CrossProduct(Iterable<E>... iterables)
	{
	    this.iterables = new ArrayList<Iterable<E>>();
        for( Iterable<E> it : iterables ) {
            this.iterables.add(it);
        }
	}
	
	public List<? extends Iterable<E>> getCollections()
	{
		return iterables;
	}

	public Iterator<List<E>> iterator()
	{
		return new CrossProductIterator<E>(this);
	}

	public static void main(String[] argv)
	{
	    List<String> v1 = new ArrayList<String>();
		List<String> v2 = new ArrayList<String>();
		List<String> v3 = new ArrayList<String>();
		
		v1.add("a");
		v1.add("b");
		v2.add("0");
		v2.add("1");
		v3.add("X");
		
		CrossProduct<String> cp = new CrossProduct<String>(v1, v2, v3, v2);
		
		Iterator<List<String>> it = cp.iterator();
		while( it.hasNext() ) {
		    List<String> tuple = it.next();
			System.out.println(tuple);
		}
		
	}
		
	
	class CrossProductIterator<InE> implements Iterator<List<InE>>
	{
        private CrossProduct<InE> cp;
		private List<Iterator<InE>> iterators;
		private List<InE> tuple;
		
		public CrossProductIterator(CrossProduct<InE> cp)
		{
            this.cp = cp;
            
			iterators = new ArrayList<Iterator<InE>>();
			tuple = new ArrayList<InE>();
			
			for(int i=0; i < cp.getCollections().size(); i++ ) {
				iterators.add(cp.getCollections().get(i).iterator());
				tuple.add(iterators.get(i).next());
			}
		}
		
		public void remove()
		{
			// I don't think there are any reasonable semantics
			// for "remove" since the "underlying collection"
			// is never actually instantiated
		    throw new UnsupportedOperationException();
        }
		
		public boolean hasNext()
		{
			return tuple != null;
		}
		
		boolean incrementFirstAvailable(int i)
		{
			if( i == iterators.size() ) {
				return true;
			}
			else if( iterators.get(i).hasNext() ) {
				tuple.set(i, iterators.get(i).next());
				return false;
			}
			else {
			    iterators.set(i, cp.iterables.get(i).iterator());
			    tuple.set(i, iterators.get(i).next());
				return incrementFirstAvailable(i+1);
			}
		}
		
		public List<InE> next()
		{
			if( tuple == null ) {
				throw new NoSuchElementException();    		
			}
			
			List<InE> result = new ArrayList<InE>();
			for(int i=0; i < tuple.size(); i++) {
				result.add(tuple.get(i));
			}
			
			if( incrementFirstAvailable(0) ) {
				tuple = null;
			}
			
			return result;
		}
	}

}

Ich will die Klasse in meinem Code jetzt so aufrufen wie hier in der main... Nur hab ich eben meine ArrayListen nicht so "lose", sondern in einer anderen ArrayList (weil aus einer for-Schleife kommend). Krieg ich die irgendwie da raus? ???:L

Oder wie mach ich das sonst? - anderen Konstruktor in der fremden Klasse schreiben??

Will mir auch keine eigene Kreuzprodukt-Klasse schreiben... Dafür hab ich zu wenig Zeit und... Ahnung ;)

Ai, mein Hirn blutet.

;( !!

Gracias im Voraus...
 

Marco13

Top Contributor
Oder Konkreter:

ArrayList<ArrayList<X>> listList = erstelle();
ArrayList<X> listA = listList.get(0);
ArrayList<X> listB = listList.get(1);
machWasMit(listA, listB);
 

Frollein

Mitglied
Man weiss aber nie wie groß die ArrayList ist, ich kann also nicht mit nem festgelegten Index über get() an die Einträge...

Ich bräuchte sowas wie meineArrayList.getAlleEinträge()...

Argh, immer noch ???:L
 

faetzminator

Gesperrter Benutzer
wie wärs mit size()? Also entweder so:
Java:
for (int i = 0; i < list.size(); i++) {
    List sublist = list.get(i);
    [...]
}
oder einfacher:
Java:
for (List sublist : list) {
    [...]
}
 

Frollein

Mitglied
Ich rufe aber die CrossProduct-Klasse außerhalb dieser Schleife auf, mit allen Sublisten, wie eben oben (die vs sind die ArrayLists):
Java:
CrossProduct<String> cp = new CrossProduct<String>(v1, v2, v3, v2);

Ich hatte es mal kurz in Erwägung gezogen, sowas zu machen wie

Java:
for(int k=0; k<meineArrayList.size(); k++){
         CrossProduct<String> cp = new CrossProduct<String>(meineArrayList.get(k), meineArrayList.get(k+1));

... dann kriege ich alle Bigramm-Kombinationen... Aber das ist eklig und übergenerierend und überhaupt nicht was ich will! Brauche, wie gesagt, die Sublisten außerhalb einer Schleife.
 

Murray

Top Contributor
Dafür ist doch der andere Konstuktor in der Klasse da, der erwartet doch anstelle der einzelnen Listen bereits eine Liste von Listen. Insofern sollte doch
Java:
CrossProduct<String> cp = new CrossProduct<String>( meineArrayList);
gehen. Und gäbe es diesen Konstruktor nicht, dann könnte man ausnutzen, dass die variable Parameterliste eigentlich nichts anderes als ein Array ist, so dass man auch folgendes machen könnte:
Java:
List<Whatever> meineArrayLIst;
/* ... */
Whatever[] meinArray = meineArrayList.toArray( new Whatever[ meineArrayList.size()0);
CrossProduct<String> cp = new CrossProduct<String>( meinArray);
 

Frollein

Mitglied
:applaus:

Juhu!! Es geht tatsächlich, wenn man die Liste zu nem Array macht! (bzw gleich so speichert, werd ich gleich mal tun. Ach nein, werd ich nicht, weiss ja die Größe nicht:oops:)

Und, nein, dieser Konstruktor mit Listen von Listen funktioniert nicht. Egal!

[bla]und inzwischen hab ich nen Großteil meines Zeugs funktionierend übersetzt... wie SCHÖÖN wenn ein Ende in Sicht is;))[/bla]

Merci lieber Murray!!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Java Tannenbaum *Argh* Java Basics - Anfänger-Themen 6
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
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
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
F Arraylist als Pfadausgabe Java Basics - Anfänger-Themen 10
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
X Problem mit Arraylist in Arraylist Java Basics - Anfänger-Themen 2
O HashMap - ArrayList Java Basics - Anfänger-Themen 29
M UML-Klassendiagramm ArrayList Java Basics - Anfänger-Themen 1
O ArrayList oberflächig durchsuchen Java Basics - Anfänger-Themen 3
I "\n" aus ArrayList enfernen, aber wie?! Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben