格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个位数的差异。
给定一个代表编码总位数的非负整数 n,打印格雷码序列。格雷码序列必须以 0 开头。
例如,给定 n = 2,返回 [0,1,3,2]
。其格雷编码是:
00 - 0 01 - 1 11 - 3 10 - 2
说明:
对于给定的 n,其格雷编码的顺序并不唯一。
例如 [0,2,3,1]
也是一个有效的格雷编码顺序。
class Solution:
def grayCode(self, n):
res = [0]
i = 0
while i < n:#从2的0次方开始,
res_inv = res[::-1]#求res的反向list
res_inv = [x + pow(2,i) for x in res_inv]
res = res + res_inv
i += 1
return res