在python中使用两个列表的值的所有可能组合来寻求求解方程的通用方法

在python中使用两个列表的值的所有可能组合来寻求求解方程的通用方法,python,for-loop,tuples,iteration,simulation,Python,For Loop,Tuples,Iteration,Simulation,我想看看这些列表的乘积的哪个组合解出一个方程,“j=k-l+m” 到目前为止,我能想到的唯一办法是如下。我使用乘积函数创建一个元组列表,如下所示 from itertools import product stake_odds=(list(product(stake,odds))) print(stake_odds) >>>[(0, 1), (0, 2), (0, 5), (0, 10), (2, 1), (2, 2), (2, 5), (2, 10), (5, 1), (5

我想看看这些列表的乘积的哪个组合解出一个方程,“j=k-l+m”

到目前为止,我能想到的唯一办法是如下。我使用乘积函数创建一个元组列表,如下所示

from itertools import product

stake_odds=(list(product(stake,odds)))
print(stake_odds)
>>>[(0, 1), (0, 2), (0, 5), (0, 10), (2, 1), (2, 2), (2, 5), (2, 10), (5, 1), (5, 2), (5, 5), (5, 10), (10, 1), (10, 2), (10, 5), (10, 10)]
然后,我再创建一个元组组合列表,元组的长度等于等式中变量的数量:

stake_odds2=(list(product(stake_odds, repeat=3)))
然后我做下面的事情

pos_combos=[]
for i in stake_odds2:
    x,y,z=i
    a,b=x
    c,d=y
    e,f=z
    k=a*b
    l=c*d
    m=e*f
    j=k-l+m
    if j > 0:
        pos_combos.append(i)
打印pos_组合返回我想要的内容。然而,我的问题是,如果我想扩展方程或两个列表,那么解包元组并标记所有内容显然会成为一场噩梦,即使是上面的内容也会让我头疼

有没有更巧妙的方法?也许有什么我应该知道的模拟软件包


提前感谢

无需解包所有这些变量,只需取元组的乘积,然后进行最后的计算

from itertools import product
import numpy as np
stake=[0,2,5,10]
odds=[1,2,5,10]
stake_odds=(list(product(stake,odds)))
stake_odds2=(list(product(stake_odds, repeat=3)))

for i in stake_odds2:
    t = [np.prod(x) for x in i]
    if t[0]-t[1]+t[2]>0:
        pos_combos.append(i)

非常好,谢谢!
from itertools import product
import numpy as np
stake=[0,2,5,10]
odds=[1,2,5,10]
stake_odds=(list(product(stake,odds)))
stake_odds2=(list(product(stake_odds, repeat=3)))

for i in stake_odds2:
    t = [np.prod(x) for x in i]
    if t[0]-t[1]+t[2]>0:
        pos_combos.append(i)