如何解决在每次跳过一个项目的 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]]
总而言之,将减去项目的整个列表添加到新列表中
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。