在 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]]
总而言之,将减去项目的整个列表添加到新列表
我有一个这样的列表,
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]]
总而言之,将减去项目的整个列表添加到新列表