4

所以我有一个像这样的文件结构(每行数据)

A
B
C
...

我想读取该文件的每一行并将它们组合成所有可能的组合,我正在寻找的结果将是这个(我会放在一个列表中)

A
AB
AC
ABC
ACB
B
BA
BC
BCA
BAC
C
CA
CB
CBA
CAB

显然,我希望处理的不仅仅是这三行......

谢谢

4

1 回答 1

5

你应该使用itertools图书馆。您想要生成 powerset 中每个元素的所有唯一排列。一些代码可能看起来像

from itertools import permutations, combinations, chain

# Taken from itertools page, but edited slightly to not return empty set
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(1, len(s)+1))

然后

In [1]: s = ('A', 'B', 'C')

In [2]: [j for i in powerset(s) for j in permutations(i)]
Out[2]: 
[('A',),
 ('B',),
 ('C',),
 ('A', 'B'),
 ('B', 'A'),
 ('A', 'C'),
 ('C', 'A'),
 ('B', 'C'),
 ('C', 'B'),
 ('A', 'B', 'C'),
 ('A', 'C', 'B'),
 ('B', 'A', 'C'),
 ('B', 'C', 'A'),
 ('C', 'A', 'B'),
 ('C', 'B', 'A')]
于 2013-08-25T18:50:28.830 回答