Heim > Java > javaLernprogramm > Wie berechnet man das kartesische Produkt mehrerer Mengen in Java?

Wie berechnet man das kartesische Produkt mehrerer Mengen in Java?

Mary-Kate Olsen
Freigeben: 2024-12-07 14:26:11
Original
865 Leute haben es durchsucht

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<Object>> cartesianProduct(Set<?>... sets) {
    if (sets.length < 2)
        throw new IllegalArgumentException("Can't have a product of fewer than two sets (got " + sets.length + ")");

    return _cartesianProduct(0, sets);
}

private static Set<Set<Object>> _cartesianProduct(int index, Set<?>... sets) {
    Set<Set<Object>> 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;
}
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage