An n-bit gray code sequence is a sequence of 2n integers where:
- Every integer is in the inclusive range [0, 2n - 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.
- back tracking solution
- Time : O(2^n * logn)
- Space : O(n)
c++
1 | class Solution { |
- greedy solution with tricky idea
c++
1 | class Solution { |