###### LeetCode89:Gray Code

The gray code is a binary numeral system where two successive values differ in only one bit.

Given a non-negative integer n representing the total number of bits in the code, print the sequence of gray code. A gray code sequence must begin with 0.

For example, given n = 2, return [0,1,3,2]. Its gray code sequence is:

00 - 0
01 - 1
11 - 3
10 - 2
Note:
For a given n, a gray code sequence is not uniquely defined.

For example, [0,2,3,1] is also a valid gray code sequence according to the above definition.

For now, the judge is able to judge based on one instance of gray code sequence. Sorry about that.

# 解法一

runtime:4ms

class Solution {
public:

vector<int> grayCode(int n) {
vector<int> result(1);
for(int i=0;i<n;i++)
{
for(int j=result.size()-1;j>=0;j--)
{
result.push_back((1<<i)+result[j]);
}
}
return result;
}
}；


# 解法二

runtime:4ms

class Solution {
public:
vector<int> grayCode(int n) {
vector<int> result;
for(int i=0;i<1<<n;i++)
{
result.push_back(i^i>>1);
}
return result;
}

};

#### [LeetCode]89.Gray Code

2014-01-23 17:04:23

#### LeetCode --- 89. Gray Code

2015-04-07 21:55:12

#### LeetCode(89)GrayCode

2014-02-14 08:07:30

#### Leetcode 89. Gray Code

2017-01-06 13:41:36

#### <LeetCode OJ> 89. Gray Code

2016-05-01 14:39:06

#### Leetcode89. Gray Code

2017-08-13 11:10:46

#### LeetCode Gray Code

2014-03-19 16:03:39

#### 【Leetcode】：89. Gray Code 问题 in JAVA

2016-05-10 14:04:39

#### leetcode笔记：Gray Code（2016腾讯软件开发笔试题）

2015-09-07 17:45:41

#### LeetCode: Gray Code

2012-10-07 13:14:24

## 不良信息举报

LeetCode89:Gray Code