力扣-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是第四位…
这些都是当前所在位右移一位然后与当前所在位做异或操作

目录
相关文章
|
8月前
leetcode-89:格雷编码
leetcode-89:格雷编码
52 0
|
8月前
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
61 0
【每日一题Day127】LC1238循环码排列 | 格雷码构造 位运算
蓝桥杯基础训练】十六进制转八进制
给定n个十六进制正整数,输出它们对应的八进制数。
84 0
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串
123 0
力扣刷题记录——392. 判断子序列、401. 二进制手表、409.最长回文串
|
算法
每日算法刷题Day9-字符串移位包含问题、字符串乘方
⭐每日算法题解系列文章旨在精选重点与易错的算法题,总结常见的算法思路与可能出现的错误,与笔者另一系列文章有所区别,并不是以知识点的形式提升算法能力,而是以实战习题的形式理解算法,使用算法。
271 0
每日算法刷题Day9-字符串移位包含问题、字符串乘方
AcWing 772. 只出现一次的字符
AcWing 772. 只出现一次的字符
83 0
AcWing 772. 只出现一次的字符
数制与编码
十进制整数转换为二进制数 可以将十进制数逐次用2除,取余数,一直到商为0.然后把全部余数按相反的次序排列起来。(除二取余)
338 0
数制与编码
|
区块链
LeetCode每日一题题解:717. 1比特与2比特字符-倒序法
LeetCode每日一题题解:717. 1比特与2比特字符-倒序法