wie finde ich alle Gruppen von Teilmengen der Menge A? Festlegen von Partitionen in Python
Ich möchte einen Algorithmus finden, der eine Menge @ gegeben hA
, um alle Gruppen von Teilmengen zu finden, die die folgende Bedingung erfüllen:
x ∪ y ∪ .... z = A, wobei x, y, ... z ∈ Gruppe
un
∀ x, y ∈ Gruppe: x ⊆ A, y ⊆ A, x ∩ y = ∅ = {}
un
∀ x ∈ Gruppe: x! = ∅
Hinweis: Ich hoffe, es gut zu definieren, ich bin nicht gut mit mathematischen Symbolen
Ich habe den folgenden Ansatz gewählt, um nur Gruppen mit zwei Teilmengen zu durchsuchen:
from itertools import product, combinations
def my_combos(A):
subsets = []
for i in xrange(1, len(A)):
subsets.append(list(combinations(A,i)))
combos = []
for i in xrange(1, 1+len(subsets)/2):
combos.extend(list(product(subsets[i-1], subsets[-i])))
if not len(A) % 2:
combos.extend(list(combinations(subsets[len(A)/2-1], 2)))
return [combo for combo in combos if not set(combo[0]) & set(combo[1])]
my_combos({1,2,3,4})
Ich erhalte die folgende Ausgabe, das sind alle Gruppen, die aus zwei Untergruppen bestehen.
[
((1,), (2, 3, 4)),
((2,), (1, 3, 4)),
((3,), (1, 2, 4)),
((4,), (1, 2, 3)),
((1, 2), (3, 4)),
((1, 3), (2, 4)),
((1, 4), (2, 3))
]
..... aber Gruppen, die aus einer, drei, vier Untergruppen bestehen ....
Frage
ie kann ich eine allgemeine Lösung finde
zum Beispiel die folgende erwartete Ausgabe:
my_combos({1,2,3,4})
[
((1,2,3,4)),
((1,2,3),(4,)),
((1,2,4),(3,)),
((1,3,4),(2,)),
((2,3,4),(1,)),
((1,2),(3,4)),
((1,3),(2,4)),
((1,4),(2,3)),
((1,2),(3,),(4,)),
((1,3),(2,),(4,)),
((1,4),(2,),(3,)),
((1,),(2,),(3,4)),
((1,),(3,),(2,4)),
((1,),(4,),(2,3)),
((1,),(4,),(2,),(3,))
]