打印出数组数组中所有元素的组合

时间:2014-03-26 15:23:04

标签: python ruby arrays numbers

说你有以下

x = [[1,2,3], [4,5,6], [7,8,9]]

在python或ruby中打印出内部元素的所有组合的最佳方法是什么?

所以结果如下:

147,
148,
149,
157,
158,
159,
167,
...

这将导致一种更通用的方式来解决典型的访谈类型问题,例如打印电话号码的所有字母组合'或者'打印数字x的位图。'

无论如何,想法?

3 个答案:

答案 0 :(得分:4)

我会用 Ruby

x = [[1,2,3], [4,5,6], [7,8,9]]
x.first.product(*x[1..-1]).map{ |ary| ary.join.to_i }
# => [147,
#     148,
#     149,
#     157,
#     158,
#     159,
#     167,
#     168,
#     169,
#     247,
#     248,
#     249,
#     257,
#     258,
#     259,
#     267,
#     268,
#     269,
#     347,
#     348,
#     349,
#     357,
#     358,
#     359,
#     367,
#     368,
#     369]

答案 1 :(得分:2)

在python中:

>>> x = [[1,2,3], [4,5,6], [7,8,9]]
>>> import itertools as it
>>> [x for x in it.product (*x) ]
[(1, 4, 7), (1, 4, 8), (1, 4, 9), (1, 5, 7), (1, 5, 8), (1, 5, 9), (1, 6, 7), (1, 6, 8), (1, 6, 9), (2, 4, 7), (2, 4, 8), (2, 4, 9), (2, 5, 7), (2, 5, 8), (2, 5, 9), (2, 6, 7), (2, 6, 8), (2, 6, 9), (3, 4, 7), (3, 4, 8), (3, 4, 9), (3, 5, 7), (3, 5, 8), (3, 5, 9), (3, 6, 7), (3, 6, 8), (3, 6, 9)]

或者如果你想要整理:

>>> [int(''.join(str(x) for x in x)) for x in it.product(*x)]
[147, 148, 149, 157, 158, 159, 167, 168, 169, 247, 248, 249, 257, 258, 259, 267, 268, 269, 347, 348, 349, 357, 358, 359, 367, 368, 369]

或者没有字符串操作:

def makeNumber(t):
    sum (10 ** i * e for i, e in enumerate(t[::-1]))
x = [[1,2,3], [4,5,6], [7,8,9]]
print([makeNumber(x) for x in it.product(*x)])

答案 2 :(得分:1)

x = [[1,2,3], [4,5,6], [7,8,9]]
x.shift.product(*x).map(&:join)