python中的笛卡尔乘积

在领扣刷题的过程中遇到需要使用笛卡尔积的解法,因为使用的是python3版本解决,所以在python版本中提供了一个库函数可以模拟笛卡尔乘积的元素组成过程:itertools.product,一般来说比较常使用的是在product方法中传递进A与B两个可迭代的对象进行组合,官方提供的解释如下:https://docs.python.org/zh-cn/3.8/library/itertools.html#itertools.product

# product('ABCD', 'xy') --> Ax Ay Bx By Cx Cy Dx Dy
# product(range(2), repeat=3) --> 000 001 010 011 100 101 110 111

上面的例子很好地解释了这个函数的常见用法,其实本质上来说是两个for循环的嵌套

依次取出A与B中的每一个元素组成元组返回,代码如下:

import itertools

if __name__ == '__main__':
     l1 = [1, 2, 3]
     l2 = ["a", "b", "c"]
     for cur in itertools.product(l1, l2):
         print(cur, end=" ")

(1, 'a') (1, 'b') (1, 'c') (2, 'a') (2, 'b') (2, 'c') (3, 'a') (3, 'b') (3, 'c') 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值