Génération d'ensembles de puissance : une approche élégante
Question :
Étant donné un ensemble, comment pouvons-nous calculer efficacement l'ensemble des pouvoirs, qui englobe tous les sous-ensembles possibles de l'original set ?
Réponse :
Le module itertools polyvalent de Python offre une solution remarquable pour la génération d'ensembles de puissance, comme démontré ci-dessous :
from itertools import chain, combinations def powerset(iterable): s = list(iterable) return chain.from_iterable(combinations(s, r) for r in range(len(s)+1))
Explication :
Sortie :
Lorsque nous appliquons cette fonction d'ensemble de puissances à un itérable contenant les éléments "abcd", il produit l'ensemble de puissances suivant :
[(), ('a',), ('b',), ('c',), ('d',), ('a', 'b'), ('a', 'c'), ('a', 'd'), ('b', 'c'), ('b', 'd'), ('c', 'd'), ('a', 'b', 'c'), ('a', 'b', 'd'), ('a', 'c', 'd'), ('b', 'c', 'd'), ('a', 'b', 'c', 'd')]
Personnalisation :
Si le tuple vide initial dans la sortie est indésirable, modifiez simplement l'instruction range pour utiliser une plage de 1 à la longueur de l'itérable plus 1, excluant ainsi les combinaisons vides de l'ensemble de puissances.
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!