Skip to content

Instantly share code, notes, and snippets.

@kmorin
Last active September 12, 2017 17:24
Show Gist options
  • Save kmorin/7fa0e22c867e376222f5201473b1b797 to your computer and use it in GitHub Desktop.
Save kmorin/7fa0e22c867e376222f5201473b1b797 to your computer and use it in GitHub Desktop.
retrive int[] of all grays code combinations
private List<int[]> getGrays(int n) {
if (n <= 0) return null;
var ar = new List<string>();
ar.Add("0");
ar.Add("1");
for (int i = 2; i < (1<<n); i=i<<1) {
for (int j = i-1; j >=0; j--) {
ar.Add(ar[j]);
}
for (int j = 0; j < i; j++) { ar[j] = $"0{ar[j]}"; }
for (int j = i; j < 2*i; j++) { ar[j] = $"1{ar[j]}"; }
}
var returnAr = new List<int[]>();
foreach (var s in ar) {
var chars = s.ToCharArray();
var tempIntArray = new int[chars.Length];
for (int i = 0; i < chars.Length; i++) {
int tempInt = int.Parse(chars[i].ToString());
tempIntArray[i] = tempInt;
}
returnAr.Add(tempIntArray);
}
return returnAr;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment