[英]Permutations inside subsets of a list in python
我有一个列表,需要获取所有排列。 但我只能在列表子集内进行排列。
所以例如我有这样的列表[1,2,3,4]
我把它分成两个子集[1,2], [3,4]
我想要一个可迭代的对象,它会给我
[1,2], [3,4]
[2,1], [3,4]
[1,2], [4,3]
[2,1], [4,3]
所以它相当于嵌套循环。 但是子集的数量可以不同,我不能将其编码为循环
尝试:
from itertools import permutations, product
x,y=[1,2],[3,4]
z=list(product(permutations(x), permutations(y)))
输出:
[((1, 2), (3, 4)), ((1, 2), (4, 3)), ((2, 1), (3, 4)), ((2, 1), (4, 3))]
你可以试试这个
import itertools
subset= [1,2,3,4]
for sin itertools.combinations(subset, 2):
print(s)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.