力扣-89. 格雷编码

简介: n 位格雷码序列 是一个由 2n 个整数组成的序列,其中:每个整数都在范围 [0, 2n - 1] 内(含 0 和 2n - 1)第一个整数是 0一个整数在序列中出现 不超过一次每对 相邻 整数的二进制表示 恰好一位不同 ,且第一个 和 最后一个 整数的二进制表示 恰好一位不同给你一个整数 n ,返回任一有效的 n 位格雷码序列 。

n 位格雷码序列 是一个由 2n 个整数组成的序列,其中:
每个整数都在范围 [0, 2n - 1] 内(含 0 和 2n - 1)
第一个整数是 0
一个整数在序列中出现 不超过一次
每对 相邻 整数的二进制表示 恰好一位不同 ,且
第一个 和 最后一个 整数的二进制表示 恰好一位不同
给你一个整数 n ,返回任一有效的 n 位格雷码序列 。

方法1:

#include <vector>
using namespace std;
int main()
{
    int n;
    cin>>n;
    vector<int> res;
    res.reserve(1 << n);  //<<左移,reserve给res开辟空间,但是此时size()还是为0
    res.push_back(0);   //添加元素到最后一个
    for(int i = 1; i <= n; i++){
        int len = res.size();
        for(int j = len - 1; j >= 0; j--){
            res.push_back(res[j] | (1 << i-1));  //|或运算,这里就是下面在首位加1
        }
    }
    for(int i = 0; i < res.size(); i++){
        cout<< res[i];
    }
return 0;

方法2:

#include <vector>
using namespace std;
int main()
{
  vector<int> ret(1 << n);    //直接开辟空间,与第一种方法不同,此时size()为2^n
    for (int i = 0; i < ret.size(); i++) {
        ret[i] = (i >> 1) ^ i;    //^异或操作
    }
    for(int i = 0; i < res.size(); i++){
        cout<< res[i];
    }
    return 0;
}

方法一:
图片.png

人话解释
图片.png

方法二:
方法二实际上是定义解法,000是第一位,001第二位,011是第三位,010是第四位…
这些都是当前所在位右移一位然后与当前所在位做异或操作

目录
相关文章
|
2天前
leetcode-89:格雷编码
leetcode-89:格雷编码
23 0
|
2天前
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
29 0
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
|
2天前
动态规划之解码方法【LeetCode】
动态规划之解码方法【LeetCode】
|
11月前
|
数据安全/隐私保护
LeetCode 1734. 解码异或后的排列
LeetCode 1734. 解码异或后的排列
50 0
|
12月前
|
算法 C++ Python
每日算法系列【EOJ 3031】二进制倒置
每日算法系列【EOJ 3031】二进制倒置
【八月】每日一题 - 761. 特殊的二进制序列
【八月】每日一题 - 761. 特殊的二进制序列
72 0
|
区块链
LeetCode每日一题题解:717. 1比特与2比特字符-倒序法
LeetCode每日一题题解:717. 1比特与2比特字符-倒序法
|
C++
【力扣·每日一题】709. 转换成小写字母(C++ 模拟)
【力扣·每日一题】709. 转换成小写字母(C++ 模拟)
33 0
【力扣·每日一题】709. 转换成小写字母(C++ 模拟)
|
算法
[leetcode] 1 比特与 2 比特字符-水题
指针i 从0 开始往后走,如果当前位置的值为0 ,则一定是第一种情况,指针向右移一位 如果说当前值为1 ,则一定是第二种情况,指针向右移动两位,如果说最终 i == bits.size() - 1 那么说就是一个合法的
81 0
[leetcode] 1 比特与 2 比特字符-水题