package
0.0.0-20241221191246-b80a13d7bbe0
Repository: https://github.com/yvv4git/go-algorithms.git
Documentation: pkg.go.dev

# README

89. Gray Code

Level - medium

Task

An n-bit gray code sequence is a sequence of 2^n integers where:

  • Every integer is in the inclusive range [0, 2^n - 1],
  • The first integer is 0,
  • An integer appears no more than once in the sequence,
  • The binary representation of every pair of adjacent integers differs by exactly one bit, and
  • The binary representation of the first and last integers differs by exactly one bit.

Given an integer n, return any valid n-bit gray code sequence.

Объяснение

Задача связана с тем, как генерировать серийную кодировку в двоичной системе счисления, которая называется кодом Грея.

Код Грея — это двоичный код, в котором два соседних значения отличаются только одним битом. Это свойство кода Грея позволяет избежать проблем, связанных с "шумными" переходами, которые могут возникнуть при использовании обычных двоичных кодов.

Задача состоит в том, чтобы написать функцию, которая генерирует серийную кодировку в двоичной системе счисления, используя код Грея. Функция должна принимать на вход целое число n, представляющее количество битов в коде Грея, и возвращать список всех двоичных строк длины n, представляющих код Грея.

Решение этой задачи может быть реализовано с помощью рекурсии или итеративного подхода.

Example 1:

Input: n = 2
Output: [0,1,3,2]
Explanation:
The binary representation of [0,1,3,2] is [00,01,11,10].
- 00 and 01 differ by one bit
- 01 and 11 differ by one bit
- 11 and 10 differ by one bit
- 10 and 00 differ by one bit
  [0,2,3,1] is also a valid gray code sequence, whose binary representation is [00,10,11,01].
- 00 and 10 differ by one bit
- 10 and 11 differ by one bit
- 11 and 01 differ by one bit
- 01 and 00 differ by one bit

Example 2:

Input: n = 1
Output: [0,1]

Constraints:

  • 1 <= n <= 16