-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathGrayCode.java
40 lines (33 loc) · 888 Bytes
/
GrayCode.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
* 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, find the sequence of gray code.
A gray code sequence must begin with 0 and with cover all
2n integers.
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.
[0,2,3,1] is also a valid gray code sequence according to
the above definition.
Challenge
O(2n) time.
*/
public class GrayCode {
/**
* @param n a number
* @return Gray code
*/
public ArrayList<Integer> grayCode(int n) {
ArrayList<Integer> result = new ArrayList<Integer>();
for (int i = 0; i < (1 << n); ++i) {
result.add(i ^ (i >> 1));
}
return result;
}
}