suchen
HeimJavajavaLernprogrammWie berechnet man das kartesische Produkt mehrerer Mengen in Java?

How to Calculate the Cartesian Product of Multiple Sets in Java?

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:

  1. Basisfall: Wenn die Anzahl der Sätze eins ist, wird ein leerer Satz zurückgegeben.
  2. Rekursiver Schritt : Für jedes Element im aktuellen Satz ruft es sich selbst rekursiv auf, um kartesische Produkte der verbleibenden Sätze zu erhalten.
  3. 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!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

MinGW – Minimalistisches GNU für Windows

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

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version