加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 获取已排序的组合

发布时间:2020-12-16 21:55:13 所属栏目: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]] 我该如何实现这一目标

我有一个输入

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__ = 

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读