格雷编码

原创 2016年06月01日 12:55:20

题目描述:格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个二进制的差异。给定一个非负整数 n ,表示该代码中所有二进制的总数,请找出其格雷编码顺序。一个格雷编码顺序必须以 0 开始,并覆盖所有的 2n 个整数。

注意事项:对于给定的 n,其格雷编码顺序并不唯一。根据以上定义, [0,2,3,1] 也是一个有效的格雷编码顺序。

样例:给定 n = 2, 返回 [0,1,3,2]。其格雷编码顺序为:

00 - 0
01 - 1
11 - 3
10 - 2

这个题其实有个小技巧(个人一直觉得这种所谓的“技巧”其实并不能真正提高编程能力),就是编码的规律。什么规律呢?通过观察我们可以发现,格雷编码是通过上一级的编码得到的。也就是n个数的编码可以通过n  - 1个数的编码得到。

如果n = 1,那么编码为[0, 1];

n = 2,编码为[00, 10, 11, 01];

n = 3,编码为[000, 100, 110, 010, 011, 111, 101, 001];

所以,n级的编码的生成,是从n - 1编码的最后一个编码开始倒序遍历,每遍历一个编码,就将这个编码+1后的码字添加到结果列表的后面,然后再将这个编码+0。

比如,n = 2,编码为[00, 10, 11, 01],倒序遍历,得到:

01,+1后生成新的码字添加到后面,再对01+0,结果列表变成[00, 10, 11, 010, 011]

接着向前遍历,对11做与上一步相同的处理,结果列表变成[00, 10, 110, 010, 011, 111];

最后,结果列表变为[000, 100, 110, 010, 011, 111, 101, 001]。这样生成的编码就是符合格雷编码条件的。也就是说,n级格雷编码是由n - 1级格雷编码生成的,这是很典型的递归思想。

最后,把二进制的字符转换成十进制整数就行。代码如下:

class Solution:
    # @param {int} n a number
    # @return {int[]} Gray code
    def grayCode(self, n):
        result = []
        if n == 0:
            return [0]
        for i in self.helper(n):
            result.append(int(i, 2))
        return result

    def helper(self, n):
        result = []
        if n == 1:
            return ["0", "1"]
        elif n > 1:
            result = self.helper(n - 1)
            index = len(result) - 1
            while index >= 0:
                temp = result[index]
                temp += "1"
                result.append(temp)
                result[index] += "0"
                index -= 1
        return result
        # Write your code here


python中,int(a, 2)的意思是将二进制字符串转换成相应的整数。
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

[LintCode] 格雷编码 Gray Code

格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个二进制的差异。 给定一个非负整数 n ,表示该代码中所有二进制的总数,请找出其格雷编码顺序。一个格雷编码顺序必须以 0 开始,并覆盖所...

411.Gray Code-格雷编码(中等题)

格雷编码 题目 格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个二进制的差异。 给定一个非负整数 n ,表示该代码中所有二进制的总数,请找出其格雷编码顺序。一个格雷编码顺序必...

格雷码的实现

问题:产生n位元的所有格雷码。 格雷码(Gray Code)是一个数列集合,每个数使用二进位来表示,假设使用n位元来表示每个数字,任两个数之间只有一个位元值不同。 例如以下为3位元的格雷码...

Java实现-格雷编码

格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个二进制的差异。 给定一个非负整数 n ,表示该代码中所有二进制的总数,请找出其格雷编码顺序。一个格雷编码顺序必须以 0 开始,并覆盖所...

gray-code

格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个二进制的差异。 给定一个非负整数 n ,表示该代码中所有二进制的总数,请找出其格雷编码顺序。一个格雷编码顺序必须以 0 开始,并覆...

格雷码编码程序

格雷编码

出处:http://wenda.tianya.cn/question/685f641eadbbb24c 格雷码 (英文:Gray Code, Grey Code,又称作葛莱码,二进制循环码)是1...

格雷的电子版

  • 2014-02-17 00:47
  • 8.04MB
  • 下载

格雷码计数器

简介实现FIFO存储器读写指针比较好的方法就是使用格雷码计数器。格雷码计数器的优势在于其相邻两个数值之间只有一位发生变化,提高了系统的抗干扰能力,而且在计数时,各个输出的门电路翻转次数要远远小于二进制...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)