python - 如何迭代笛卡尔积以便首先组合顶级项目?

标签 python iteration python-itertools

我需要获得可迭代对象的笛卡尔积,就像 itertools.product 给我的那样,但出于优化原因,我希望索引总和最低的那些对/组合首先出现。

例如,如果我有两个列表,a = [1, 2, 3, 4, 5]b = ['a', 'b', ' c', 'd', 'e'], itertools.product 给我:

>>> list(itertools.product(a, b))
[(1, 'a'), (1, 'b'), (1, 'c'), (1, 'd'), (1, 'e'), (2, 'a'), (2, 'b'), (2, 'c'), (2, 'd'), (2, 'e'), (3, 'a'), (3, 'b'), (3, 'c'), (3, 'd'), (3, 'e'), (4, 'a'), (4, 'b'), (4, 'c'), (4, 'd'), (4, 'e'), (5, 'a'), (5, 'b'), (5, 'c'), (5, 'd'), (5, 'e')]

相反,我希望在 (1, 'c') 之前看到 (2, 'a')。确切的顺序,例如(1, 'b')(2, 'a') 并不重要。


目前,我正在根据索引范围的乘积对列表进行排序:

>>> sorted(list(itertools.product(range(len(a)), range(len(b)))), lambda a, b: sum(a) - sum(b))
[(0, 0), (0, 1), (1, 0), (0, 2), (1, 1), (2, 0), (0, 3), (1, 2), (2, 1), (3, 0), (0, 4), (1, 3), (2, 2), (3, 1), (4, 0), (1, 4), (2, 3), (3, 2), (4, 1), (2, 4), (3, 3), (4, 2), (3, 4), (4, 3), (4, 4)]

然后用它来索引列表。然而,对于长列表来说,这会占用太多内存。我需要某种与 itertools.product 具有相同调用约定的生成器,但我无法找出迭代的方法,以便我一次获得排序和所有可能的对。

最佳答案

def cartprod(x,y):
    nx = len(x)
    ny = len(y)
    for i in range(nx+ny):
        for j in range(max(0,i-ny+1), min(i+1,nx)):
            yield (x[j],y[i-j])

关于python - 如何迭代笛卡尔积以便首先组合顶级项目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32603278/

相关文章:

python - 如何拆分字符串(输入)并将每个部分用作字典值?

c++ - 迭代中的指针算法是否溢出安全?

java - 迭代循环至少 1000 次

python - 有没有办法有效地计算两个(或更多)迭代器的乘积?

python - 使用 itertools groupby 创建列表列表

python - Itertools 生成乱码组合

python - 清理推文的问题(表情符号、笑脸......)

python - 如何绘制线性回归?

python:从给定列表中删除一组时出现KeyError

c++ - 使用迭代器从双 for 循环构建 vector