Kartesisches Produkt mehrerer Mengen in Java
Die Bestimmung des kartesischen Produkts von zwei oder mehr Mengen ist eine häufige Aufgabe in der Programmierung. So führen Sie diesen Vorgang mithilfe von Java-Bibliotheken durch.
Rekursiver Ansatz
Für eine beliebige Anzahl von Mengen kann ein rekursiver Ansatz verwendet werden. Die Methode „cartesianProduct“ akzeptiert ein Array von Mengen als Argumente. Es prüft, ob die Anzahl der Sätze gültig ist und fährt mit den folgenden Schritten fort:
- Basisfall: Wenn die Anzahl der Sätze eins ist, wird ein leerer Satz zurückgegeben.
- Rekursiver Schritt : Für jedes Element im aktuellen Satz ruft es sich selbst rekursiv auf, um kartesische Produkte der verbleibenden Sätze zu erhalten.
- Fügt das aktuelle Element zu jedem Produkt aus hinzu rekursiver Aufruf und fügt ihn der Ergebnismenge hinzu.
Beispielcode:
public static Set<set>> cartesianProduct(Set>... sets) { if (sets.length > _cartesianProduct(int index, Set>... sets) { Set<set>> ret = new HashSet(); if (index == sets.length) { ret.add(new HashSet()); } else { for (Object obj : sets[index]) { for (Set<object> set : _cartesianProduct(index + 1, sets)) { set.add(obj); ret.add(set); } } } return ret; }</object></set></set>
Hinweis: Dieser Ansatz garantiert einen kartesischen Produkt für eine beliebige Anzahl von Sätzen, kann jedoch aufgrund der Einschränkungen von Java keine generischen Typinformationen beibehalten.
Das obige ist der detaillierte Inhalt vonWie berechnet man das kartesische Produkt mehrerer Mengen in Java?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version