靈感來自https://stackoverflow.com/a/15538456/1219006
n = 2
[[[i>>k&1 for k in range(j, j-8, -1)] for j in range(8*n-1, 0, -8)]
for i in range(2**(8*n))]
你需要運行t他對Python 3的大號n
因爲xrange
不支持大整數。
作爲發電機:
def byte_array(n):
for i in range(2**(8*n)):
yield [[i>>k&1 for k in range(j, j-8, -1)] for j in range(8*n-1, 0, -8)]
>>> i = byte_array(4)
>>> next(i)
[[0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0]]
>>> next(i)
[[0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 1]]
或者,如果你不希望他們做分組它更簡單:
[[i>>j&1 for j in range(8*n-1, -1, -1)] for i in range(2**(8*n))]
等效發電機:
def byte_array(n):
for i in range(2**(8*n)):
yield [i>>j&1 for j in range(8*n-1, -1, -1)]
最壞的情況n大概是8; 2^64納秒= 585年 – 2013-04-29 04:48:10
@JasonS:這是恆定的時間!大聲笑 – Mehrdad 2013-04-29 04:49:34
我不需要所有的組合:)我只需要提示如何實現 - 實際使用情況會有所不同。 – 2013-04-29 04:52:28