在尝试为真值表生成函数编写代码时出现了这个问题.
如何生成所有length-n排列True和False的列表?换句话说,给定元素列表[True,False],如何生成这些元素的所有可能长度-n组合的所有排列?
例如:
n = 2长度 – 2个排列是:
[[True, True], [True, False], [False, True], [False, False]]
n = 3长度为3的排列为:
[[False, False, False],[False,False,True],
[False,True,False],[False,True,True],
[True,False,False],[True,False,True],[True,True,False],[True,True,True]]
我知道这个列表中有2 ^ n个列表.我也考虑过使用itertools.product,但这似乎只是给出了特定组合的排列.在这种情况下,我想我想生成长度为n的真/假列表的所有组合的排列.
解决方法:
使用产品:
>>> import itertools
>>> l=[False,True]
>>> list(itertools.product(l,repeat=3))
[(False, False, False), (False, False, True), (False, True, False), (False, True, True), (True, False, False), (True, False, True), (True, True, False), (True, True, True)]
>>>
并列出一个清单:
>>> import itertools
>>> l=[False,True]
>>> [list(i) for i in itertools.product(l,repeat=3)]
[[False, False, False], [False, False, True], [False, True, False], [False, True, True], [True, False, False], [True, False, True], [True, True, False], [True, True, True]]
>>>