recherche
MaisonJavajavaDidacticielComment calculer le produit cartésien d'un nombre arbitraire d'ensembles en Java ?

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

Produit cartésien d'un nombre arbitraire d'ensembles en Java

Lorsqu'il s'agit de plusieurs ensembles, une opération courante consiste à calculer leur produit cartésien, qui génère un ensemble contenant tous les combinaisons d’éléments des ensembles d’entrée. Pour faciliter cela en Java, explorons une solution qui gère un nombre arbitraire d'ensembles.

Approche récursive pour le produit cartésien

La méthode Java récursive suivante, cartesianProduct, calcule le produit cartésien d'un nombre quelconque d'ensembles :

public static Set<set>> cartesianProduct(Set>... sets) {
    if (sets.length <p>La méthode d'assistance récursive, _cartesianProduct, construit le produit cartésien en ajoutant itérativement des éléments de chaque ensemble aux ensembles accumulés :</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>

Exemple d'utilisation

Pour démontrer l'utilisation de cette méthode, considérons l'exemple fourni dans la question, où nous avons trois ensembles contenant des objets des classes Person, Gift et GiftExtension. Nous pouvons obtenir le produit cartésien de ces ensembles comme suit :

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

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

Le produit cartésien résultant contiendra des ensembles représentant toutes les combinaisons possibles de personnes, de cadeaux et d'extensions de cadeaux.

Générique Informations sur le type

Il est important de noter que le système de types de Java ne permet pas aux méthodes de renvoyer des types génériques avec un nombre arbitraire de paramètres. Cela signifie que la méthode cartesianProduct renvoie Set>, quels que soient les types d'éléments dans les ensembles d'entrée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel