匹配排列:对齐长列表和短列表
给定两个不同长度的列表,我们的目标是根据列表的长度创建配对更短的列表。较短列表中的每个元素应对应于较长列表中元素的排列。
例如,名称 = ['a', 'b'] 且数字 = [1, 2],我们将获得:
[('a', 1), ('b', 2)] [('b', 1), ('a', 2)]
如果名称列表较长,例如名称 = ['a', 'b', 'c'],则排列将扩展为包括:
[('a', 1), ('b', 2)] [('b', 1), ('a', 2)] [('a', 1), ('c', 2)] [('c', 1), ('a', 2)] [('b', 1), ('c', 2)] [('c', 1), ('b', 2)]
使用 itertools.product 的解决方案
一种简单的方法是利用 Python 标准库中的 itertools.product 函数。它生成输入迭代的笛卡尔积,创建所有可能的组合。
import itertools a = ["foo", "melon"] b = [True, False] c = list(itertools.product(a, b)) # Output: # [("foo", True), ("foo", False), ("melon", True), ("melon", False)]
在我们的特定情况下,我们可以使用 itertools.product 将较短列表的元素与较长列表的排列配对。排列是通过列出较长列表元素的所有可能的重新排序来生成的。
以上是如何使用排列将短列表和长列表中的元素配对?的详细内容。更多信息请关注PHP中文网其他相关文章!