How can I create a Set of Sets in Python?
Solution 1:
Python's complaining because the inner set
objects are mutable and thus not hashable. The solution is to use frozenset
for the inner sets, to indicate that you have no intention of modifying them.
Solution 2:
People already mentioned that you can do this with a frozenset(), so I will just add a code how to achieve this:
For example you want to create a set of sets from the following list of lists:
t = [[], [1, 2], [5], [1, 2, 5], [1, 2, 3, 4], [1, 2, 3, 6]]
you can create your set in the following way:
t1 = set(frozenset(i) for i in t)
Solution 3:
Use frozenset
inside.
Solution 4:
As of 2020, the official Python documentation advises using frozenset
to represent sets of sets.
Solution 5:
So I had the exact same problem. I wanted to make a data structure that works as a set of sets. The problem is that the sets must contain immutable objects. So, what you can do is simply make it as a set of tuples. That worked fine for me!
A = set()
A.add( (2,3,4) )##adds the element
A.add( (2,3,4) )##does not add the same element
A.add( (2,3,5) )##adds the element, because it is different!