格雷码
格雷码是一个二进制数系,其中两个相邻数的二进制位只有一位不同。举个例子,
注意序列的下标我们以 
格雷码由贝尔实验室的 Frank Gray 于 1940 年代提出,并于 1953 年获得专利。
构造格雷码(变换)
格雷码的构造方法很多。我们首先介绍手动构造方法,然后会给出构造的代码以及正确性证明。
手动构造
- 翻转最低位得到下一个格雷码,(例如 - 把最右边的 
交替按照上述策略生成 
镜像构造
计算方法
我们观察一下 
| 1 |  | 
正确性证明
接下来我们证明一下,按照上述公式生成的格雷码序列,相邻两个格雷码的二进制位有且仅有一位不同。
我们考虑 
于是我们在计算 
证毕。
通过格雷码构造原数(逆变换)
接下来我们考虑格雷码的逆变换,即给你一个格雷码 
| 1 2 3 4 5 |  | 
实际应用
格雷码有一些十分有用的应用,有些应用让人意想不到:
- 格雷码被用于最小化数字模拟转换器(比如传感器)的信号传输中出现的错误,因为它每次只改变一个位。 
- 格雷码可以用来解决汉诺塔的问题。 - 设盘的数量为 - 由于每一次只有一个二进制位会改变,因此当第 - 如果 - 如果 - 格雷码也在遗传算法理论中得到应用。 
习题
- CSP S2 2019 D1T1 Difficulty: easy 
- SGU #249 Matrix Difficulty: medium 
本页面部分内容译自博文 Код Грея 与其英文翻译版 Gray code。其中俄文版版权协议为 Public Domain + Leave a Link;英文版版权协议为 CC-BY-SA 4.0。
本页面最近更新:2023/12/17 01:05:16,更新历史
发现错误?想一起完善? 在 GitHub 上编辑此页!
本页面贡献者:frank-xjh, Ir1d, ouuan, sshwy, StudyingFather, CCXXXI, danni, Early0v0, Enter-tainer, Henry-ZHR, infiWang, mingyEx, Tiphereth-A, Yanjun-Zhao
本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用