比如说,我有下面的偶数名称列表,结果应该返回表示成对的名称:
['A', 'B', 'C', 'D']
>>> [[('B', 'C'), ('A', 'D')],
[('A', 'B'), ('C', 'D')],
[('A', 'C'), ('B', 'D')]]
我编写了以下代码:
import itertools
combinations = list(itertools.combinations(['A', 'B', 'C', 'D'], 2))
result = []
for i in range( 0 , len(combinations) ):
if (combinations[i-1][0] != combinations[i][0]) & (combinations[i-1][0] != combinations[i][1]) :
if (combinations[i-1][1] != combinations[i][0]) & (combinations[i-1][1] != combinations[i][1]) :
zipped = zip(combinations[i], combinations[i-1])
result.append(list(zipped))
result
但其结果是:
[[('A', 'C'), ('B', 'D')],
[('B', 'A'), ('C', 'D')]]
我的代码中缺少什么
这是一个棘手的小问题,尤其是当扩展到四个以上的名称时。我在这里做的是创建四个名称的所有排列。然后,为了确定唯一性,我对这些对进行排序,并对这些对的列表进行排序。然后我保留那些独一无二的
四个名称的输出:
六个名称的输出:
相关问题 更多 >
编程相关推荐