suchen
HeimJavajavaLernprogrammWie berechnet man das kartesische Produkt einer beliebigen Anzahl von Mengen in Java?

How to Compute the Cartesian Product of an Arbitrary Number of Sets in Java?

Kartesisches Produkt einer beliebigen Anzahl von Mengen in Java

Beim Umgang mit mehreren Mengen ist eine übliche Operation die Berechnung ihres kartesischen Produkts, das eine Menge generiert, die alle möglichen enthält Kombinationen von Elementen aus den Eingabemengen. Um dies in Java zu erleichtern, untersuchen wir eine Lösung, die eine beliebige Anzahl von Mengen verarbeitet.

Rekursiver Ansatz für kartesisches Produkt

Die folgende rekursive Java-Methode, kartesisches Produkt, berechnet das kartesische Produkt beliebig vieler Mengen:

public static Set<set>> cartesianProduct(Set>... sets) {
    if (sets.length <p>Die rekursive Hilfsmethode, _cartesianProduct, konstruiert das kartesische Produkt durch iteratives Hinzufügen von Elementen aus jeder Menge zu den akkumulierenden Mengen:</p>
<pre class="brush:php;toolbar:false">private static Set<set>> _cartesianProduct(int index, Set>... sets) {
    Set<set>> ret = new HashSet<set>>();
    if (index == sets.length) {
        ret.add(new HashSet<object>());
    } else {
        for (Object obj : sets[index]) {
            for (Set<object> set : _cartesianProduct(index + 1, sets)) {
                set.add(obj);
                ret.add(set);
            }
        }
    }
    return ret;
}</object></object></set></set></set>

Beispielverwendung

Um die Verwendung dieser Methode zu demonstrieren, betrachten Sie Folgendes das in der Frage bereitgestellte Beispiel, in dem wir drei Mengen haben, die Objekte der Klassen Person, Gift und GiftExtension enthalten. Wir können das kartesische Produkt dieser Sets wie folgt erhalten:

Set<person> persons = ...;
Set<gift> gifts = ...;
Set<giftextension> giftExtensions = ...;

Set<set>> cartesianProduct = cartesianProduct(persons, gifts, giftExtensions);</set></giftextension></gift></person>

Das resultierende kartesische Produkt enthält Sets, die alle möglichen Kombinationen von Personen, Geschenken und Geschenkerweiterungen darstellen.

Generisch Typinformationen

Es ist wichtig zu beachten, dass das Typsystem von Java nicht zulässt, dass Methoden generische Typen mit einem beliebigen Wert zurückgeben Anzahl der Parameter. Das bedeutet, dass die Methode „cartesianProduct“ Set> zurückgibt, unabhängig von den Elementtypen in den Eingabesätzen.

Das obige ist der detaillierte Inhalt vonWie berechnet man das kartesische Produkt einer beliebigen Anzahl von 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

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software