python – 获取已排序的组合

前端之家收集整理的这篇文章主要介绍了python – 获取已排序的组合前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个输入

A = [2,1,3,2,0].

下面我删除所有重复项

A = list(Set(A))

A现在是[0,3].现在我希望我可以使用此列表进行所有对组合,但它们不需要是唯一的…因此[0,3]等于[3,0]和[2,2] .在这个例子中它应该返回

[[0,1],[0,2],3],[1,[2,3]]

我该如何实现这一目标?我查看了iteratools lib.但无法提出解决方案.

最佳答案
>>> A = [2,0]
>>> A = sorted(set(A))   # list(set(A)) is not usually in order
>>> from itertools import combinations
>>> list(combinations(A,2))
[(0,1),(0,2),3),(1,(2,3)]

>>> map(list,combinations(A,2))
[[0,3]]
>>> help(combinations)
Help on class combinations in module itertools:

class combinations(__builtin__.object)
 |  combinations(iterable,r) --> combinations object
 |  
 |  Return successive r-length combinations of elements in the iterable.
 |  
 |  combinations(range(4),3) --> (0,3)
 |  
 |  Methods defined here:
 |  
 |  __getattribute__(...)
 |      x.__getattribute__('name') <==> x.name
 |  
 |  __iter__(...)
 |      x.__iter__() <==> iter(x)
 |  
 |  next(...)
 |      x.next() -> the next value,or raise StopIteration
 |  
 |  ----------------------------------------------------------------------
 |  Data and other attributes defined here:
 |  
 |  __new__ = 

猜你在找的Python相关文章