给定一个二进制的位数n,求出一个0到2^n-1的排列,使得相邻两项(包含头尾两项)的二进制表达中只有一位恰好不同。
说明:格雷码的第i位是i xor (i >> 1),简单的O(2^n)
vector<int> Grey_Create(int n)
{
vector<int> res;
res.clear();
for(int i = 0;i < (1 << n);i++) res.push_back(i ^ (i >> 1));
return res;
}
最后
以上就是危机微笑最近收集整理的关于求n位的格雷码的全部内容,更多相关求n位内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复