7

假设我有一个这样的原子数组:

['a', 'b', 'c']

(长度可以是任意的)

我想创建一个可以用它们制作的集合列表:

[  
    ['a'], ['b'], ['c'],  
    ['a', 'b'], ['a', 'c'], ['b', 'c'],  
    ['a', 'b', 'c']  
]  

是否可以在 python 中轻松完成?

也许这很容易做到,但我自己没有得到它。
谢谢你。

4

3 回答 3

15

这对我来说听起来像powerset

def powerset(iterable):
    "powerset([1,2,3]) --> () (1,) (2,) (3,) (1,2) (1,3) (2,3) (1,2,3)"
    s = list(iterable)
    return chain.from_iterable(combinations(s, r) for r in range(len(s)+1))
于 2012-04-28T22:06:20.677 回答
4

简单的。使用itertools.combinations()

from itertools import combinations

atom = list('abc')

combs = [i for j in range(1, len(atom) + 1) for i in combinations(atom, j)]

产生:

[('a',), ('b',), ('c',), ('a', 'b'), ('a', 'c'), ('b', 'c'), ('a', 'b', 'c')]
于 2012-04-28T22:15:18.280 回答
0

你也可以这样做:

from itertools import product
masks = [p for p in product([0, 1], repeat=len(data))]
combs = [[x for i, x in enumerate(data) if mask[i]] for mask in masks]
于 2012-09-10T22:59:50.430 回答