【问题标题】:Find all possible combination in a python list skipping an item each time在每次跳过一个项目的python列表中查找所有可能的组合
【发布时间】:2021-03-04 08:08:12
【问题描述】:

我有一个这样的列表,

l=[1,2,3,4]

现在我想从 l 创建其他列表,其中下一个值每次都会消失,所以输出将是

[[2,3,4], [1,3,4],[1,2,4], [1,2,3]]

再举几个例子,

 [1,2] --> [[2], [1]] 
 [10,32,15] --->[[32,15], [10,15], [10,32]]

我可以使用 for 循环来做到这一点,但我正在寻找一种 Python 的方式来更有效地做到这一点。

【问题讨论】:

标签: python python-3.x list list-comprehension


【解决方案1】:

您可以使用itertools.combinations 来完成这项工作

list(itertools.combinations([1,2,3,4], 3))
[(1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)]

如果您需要将元素作为列表而不是元组,则可以稍作修改:

[list(elem) for elem in itertools.combinations([1,2,3,4], 3)]
[[1, 2, 3], [1, 2, 4], [1, 3, 4], [2, 3, 4]]

【讨论】:

    【解决方案2】:
    > old_list = [1, 2, 3, 4] 
    > new_list = [] 
    > for ITEM in old_list:
    >     copy_old_list = old_list[:]
    >     copy_old_list.remove(ITEM)
    >     new_list.append(copy_old_list) 
    > print(new_list)
    [2, 3, 4], [1, 3, 4], [1, 2, 4], [1, 2, 3]]
    

    总而言之,将减去项目的整个列表添加到新列表中

    【讨论】:

      猜你喜欢
      • 2021-02-10
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-10-15
      • 1970-01-01
      相关资源
      最近更新 更多