在每次跳过一个项目的 python 列表中查找所有可能的组合

问题描述

我有一个这样的清单,

l=[1,2,3,4]

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

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

再举几个例子

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

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

解决方法

您可以将 {{3}} 用于作业

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

如果你需要元素是列表而不是元组,稍微修改一下:

[list(elem) for elem in itertools.combinations([1,3)]
[[1,3],[1,[2,4]]
,
> old_list = [1,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]]

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...