2010-06-02 63 views

回答

2

itertools recipes

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)) 

這是一個標準的Python模塊,所以在閱讀,應該給你的見解它是如何實現的以及使用什麼算法。我不知道它是否是最好的,但它是來自現實世界的算法。