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

Find all possible combination in a python list skipping an item each time

我有一个这样的列表,

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 循环来完成,但我正在寻找一种更有效的 pythonic 方式。

您可以使用 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]]
> 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]]

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