用itertools.product简化嵌套for循环

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用itertools.product简化嵌套for循环相关的知识,希望对你有一定的参考价值。

今天这一题叫做“偷瞄到的密码”:

警察跟踪一名窃贼来到了一个仓库门前。仓库的密码锁盘如下:

1 2 3

4 5 6

7 8 9

   0

窃贼输入密码后进了门。警察“觉得”自己看到了密码比如1357,但是也有可能是相邻的数字(相邻仅包括正上下左右,不包括对角线),比如第一位不是1,而是相邻的4和2(不包括5)。

可能的密码是哪些组合呢?

这道题目可以抽象成:

1. 0-9各自都对应了一组相邻数字

现给定一个数字串:

2. 对数字串中的每个数字,找到对应的相邻数组

3. 计算从这些相邻组中各挑一个形成的所有可能组合并输出

实现要点:

1. 上述#3实际上是一个嵌套的多重for循环:

  for 数字串中的每个数字:

    for 该数字相邻数组中的每个数字:

用itertools模块的product方法可以将这个过程简化为一步完成。根据Python手册,product(A, B)的结果是((x,y) for in for in B)。

2. 对于函数或者方法如product(A, B, C, D),如果ABCD在一个列表里ls=[A, B, C, D],如何把ls传给product?

用*,即product(*ls)。

3. product的输出为元组。用join合并元组的所有元素,以字符串的形式输出密码组合。

借用某个最佳实现

from itertools import product

ADJACENTS = (08, 124, 2135, 326, 4157, 52468, 6359, 748, 85790, 968)

def get_pins(observed):
    return [‘‘.join(p) for p in product(*(ADJACENTS[int(d)] for d in observed))]

暴力破解密码之后,窃贼就是瓮中之鳖啦!

以上是关于用itertools.product简化嵌套for循环的主要内容,如果未能解决你的问题,请参考以下文章

itertools.product 比嵌套 for 循环慢

itertools.product(np.arange(0.0, 1.1, 0.1), repeat=30) 杀死进程

Python for 循环偏移 (Itertools.product)

Python itertools.product 具有可变数量的参数

Python小技巧:使用*解包和itertools.product()求笛卡尔积(转)

Python的itertools.product 方法