Maison > développement back-end > Tutoriel Python > Comment pouvons-nous générer toutes les partitions d'ensemble possibles en Python ?

Comment pouvons-nous générer toutes les partitions d'ensemble possibles en Python ?

Linda Hamilton
Libérer: 2024-11-06 01:57:02
original
847 Les gens l'ont consulté

How can we generate all possible set partitions in Python?

Définir des partitions en Python

En Python, une partition d'un ensemble est une collection de sous-ensembles disjoints dont l'union est l'ensemble d'origine. Considérons le tableau [1,2,3]. Notre objectif est de générer toutes les combinaisons possibles en utilisant tous les éléments du tableau, ce qui donne lieu à des partitions telles que [[1], [2], [3]], [[1,2], [3]], etc.

Pour y parvenir, nous utilisons une approche récursive. Pour une partition d'éléments "n-1", nous avons deux options lors de l'incorporation du "n"ème élément : soit l'attribuer à un sous-ensemble existant, soit créer un nouveau sous-ensemble. Ce processus exhaustif garantit la génération de toutes les partitions valides.

Par exemple, partitionnons le tableau [1,2,3]. En commençant par le cas de base d'un seul élément, nous obtenons [[1]]. En passant à l'élément suivant, nous insérons 2 dans chaque sous-ensemble de la partition [1], ce qui donne [[2], [1]]. Nous créons également un nouveau sous-ensemble [[2,1]].

En continuant de manière récursive, nous incorporons l'élément 3 dans les partitions. Nous insérons 3 dans chaque sous-ensemble de la partition [[2], [1]], ce qui donne [[3,2], [1]] et [[2,3], [1]]. Nous créons également un nouveau sous-ensemble [[3,1],[2]].

En suivant ce modèle, nous générons de manière exhaustive toutes les partitions possibles du tableau. Le résultat résultant serait :

[[1], [2], [3]]
[[1,2], [3]]
[[1], [2,3]]
[[1,3], [2]]
[[1,2,3]]
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal