我試圖想出一個 Python 腳本來查找兩個列表元素的所有成對組合(不管它們的元素的相對數量)。例如,如果A = ["a", "b", "c"]和B = [1, 2],則可能的對組合從 B 中取 1 個元素,然后從 B 中取 2 個元素,依此類推,針對所有A 的元素是(沒有重復):(1, 'a')(1, 'b')(1, 'c')(2, 'a')(2, 'b')(2, 'c')[(1, 'a'), (2, 'a')][(1, 'a'), (2, 'b')][(1, 'a'), (2, 'c')][(1, 'b'), (2, 'a')][(1, 'b'), (2, 'b')][(1, 'b'), (2, 'c')][(1, 'c'), (2, 'a')][(1, 'c'), (2, 'b')][(1, 'c'), (2, 'c')]如果A = ["a", "b", "c"]和B = [1, 2, 3],則前 43 種組合使用 B 的 1 個元素,然后使用 B 的 2 個元素,依此類推A 的元素應該是:(1, 'a')(1, 'b')(1, 'c')(2, 'a')(2, 'b')(2, 'c')(3, 'a')(3, 'b')(3, 'c')[(1, 'a'), (2, 'a')][(1, 'a'), (2, 'b')][(1, 'a'), (2, 'c')][(1, 'b'), (2, 'a')][(1, 'b'), (2, 'b')][(1, 'b'), (2, 'c')][(1, 'c'), (2, 'a')][(1, 'c'), (2, 'b')][(1, 'c'), (2, 'c')][(1, 'a'), (3, 'a')][(1, 'a'), (3, 'b')][(1, 'a'), (3, 'c')][(1, 'b'), (3, 'a')][(1, 'b'), (3, 'b')][(1, 'b'), (3, 'c')][(1, 'c'), (3, 'a')][(1, 'c'), (3, 'b')][(1, 'c'), (3, 'c')][(2, 'a'), (3, 'a')][(2, 'a'), (3, 'b')][(2, 'a'), (3, 'c')][(2, 'b'), (3, 'a')][(2, 'b'), (3, 'b')][(2, 'b'), (3, 'c')][(2, 'c'), (3, 'a')][(2, 'c'), (3, 'b')][(2, 'c'), (3, 'c')][(1, 'a'), (2, 'a'), (3, 'a')][(1, 'a'), (2, 'a'), (3, 'b')][(1, 'a'), (2, 'a'), (3, 'c')][(1, 'a'), (2, 'b'), (3, 'a')][(1, 'a'), (2, 'b'), (3, 'b')][(1, 'a'), (2, 'b'), (3, 'c')][(1, 'a'), (2, 'c'), (3, 'a')] : : : : : :這是我嘗試使用此處的代碼所做的,
1 回答

精慕HU
TA貢獻1845條經驗 獲得超8個贊
我沒有讀過你的代碼,但我找到了一個解決方案:對于每個尺寸,獲得 A 與尺寸重復的產品,獲得尺寸B 的組合,然后獲得它們的產品和 zip。
from itertools import combinations, product
for size in range(1, len(B)+1):
a = product(A, repeat=size)
b = combinations(B, r=size)
for x, y in product(b, a):
print(list(zip(x, y)))
輸出B = [1, 2]:
[(1, 'a')]
[(1, 'b')]
[(1, 'c')]
[(2, 'a')]
[(2, 'b')]
[(2, 'c')]
[(1, 'a'), (2, 'a')]
[(1, 'a'), (2, 'b')]
[(1, 'a'), (2, 'c')]
[(1, 'b'), (2, 'a')]
[(1, 'b'), (2, 'b')]
[(1, 'b'), (2, 'c')]
[(1, 'c'), (2, 'a')]
[(1, 'c'), (2, 'b')]
[(1, 'c'), (2, 'c')]
的輸出B = [1, 2, 3]與您的輸出相同。
添加回答
舉報
0/150
提交
取消