算法与数据结构(格雷编码)

news/2025/2/26 6:06:40

题目

思路

首先我们先看一下格雷编码的一些情况,为了一会方便理解,我们看它的二进制情况。

当n=1时,输出[0,1]

当n=2时,输出[00,01,11,10]

当n=3时,输出[000, 001, 011, 010, 110, 111, 101, 100]

我们可以看到2的前半部分就是1,3的前半部分就是2。

所以我们只需要求后半部分即可,

格雷码的生成有一个递推公式。已知n-1位的格雷码,如何得到n位的?方法是,首先将n-1位的格雷码列表逆序,然后每个数的最高位设为1,然后拼接到原来的列表后面。例如,n=1的格雷码是0,1。n=2的时候,将之前的逆序是1,0,然后前面加上最高位1,变成11,10,然后拼接到原来的00,01后面,得到00,01,11,10,对应十进制的0,1,3,2。

总结一下,就是:

  • 将k-1位序列逆序。

  • 对逆序后的每个元素,在最高位(即第k-1位)添加1。

  • 将新生成的序列追加到原序列之后。

代码详解

首先,定义一个ans用来存储格雷码序列。

ans.reserve是将ans的capacity容量扩大,n位格雷码有2^n个序列,所以就给他2^n的空间。

至于里面为什么是1<<n。

它的意思就是把1向左移动n位

n=1, 移动完:10              2^1=2

n=2, 移动完:100            2^2=4

n=3, 移动完:1000          2^3=8

接着将里面的变量初始化为0。

for(int i=1;i<=n;i++) 这个是用来逐位构造格雷码的,对于n=1,只会循环一次

int m =ans.size();

这个是求ans现有的元素数

for(int j=m-1;j>=0;j--)
            {
                ans.push_back(ans[j] | (1 << (i-1)));
            }

这个就是对里面现有的数进行倒序访问。

ans.push_back(ans[j] | (1 << (i-1)));

这个是1左移i-1位与原有的数相或。如果i=1,就是1左移0位,其实他就是用来将第i-1位设为1,并添加到结果中。

当n=1时,输出[0,1]

当n=2时,输出[00,01,11,10]

对于这个例子,n=2就是将第二位设为1,分别是11,10并添加到序列中,因为是逆序,所以先给1加,后给0加。

最后返回ans即可。

代码

class Solution {
public:
    vector<int> grayCode(int n) {
        vector<int> ans;
        ans.reserve(1<<n);
        ans.push_back(0);
        for(int i=1;i<=n;i++)
        {
            int m =ans.size();
            for(int j=m-1;j>=0;j--)
            {
                ans.push_back(ans[j] | (1 << (i-1)));
            }
        }
        return ans;
    }
};


http://www.niftyadmin.cn/n/5868144.html

相关文章

栅格地图路径规划:基于雪橇犬优化算法(Sled Dog Optimizer,SDO)的移动机器人路径规划(提供MATLAB代码)

一、雪橇犬优化算法 雪橇犬优化算法&#xff08;Sled Dog Optimizer&#xff0c;SDO&#xff09;是一种于2024年10月发表在JCR1区、中科院1区SCI期刊《Advanced Engineering Informatics》的仿生元启发式算法。它受雪橇犬行为模式启发&#xff0c;通过模拟狗拉雪橇、训练和退役…

2025考研国家线首次全面下降,涵盖与24年对比分析!

2025年研考国家线发布&#xff0c;“调剂意向采集系统”将于3月28日开通&#xff1b;“调剂服务系统”将于4月8日开通。 “中国研究生招生信息网”中“调剂意向采集系统”将于3月28日开通&#xff0c;已完成一志愿录取的招生单位可发布调剂信息&#xff0c;有调剂意愿的考生可查…

HarmonyOS 无线调试

下载sdk 找到hdc位置> C:\Users\27638\AppData\Local\OpenHarmony\Sdk\14\toolchains 不要去DevEco Studio的窗口不知道为什么调不动 hdc tconn IP:PORT

基于FastGPT搭建本地DeepSeek R1服务+AI专属知识库

在这个快速发展的AI时代,如何高效搭建本地智能系统成为了许多开发者和企业关注的焦点。为了帮助轻松搭建一个强大的本地AI服务详细介绍如何通过一键部署 LM Studio + DeepSeek R1,并搭建 AI 专属知识库。 通过这个过程可以实现对自定义数据的快速处理、无缝集成以及数据安全…

Unity中动态切换光照贴图的方法

关键代码&#xff1a;LightmapSettings.lightmaps lightmapDatas; LightmapData中操作三张图&#xff1a;lightmapColor,lightmapDir,以及一张ShadowMap 这里只操作前两张&#xff1a; using UnityEngine; using UnityEngine.EventSystems; using UnityEngine.UI;public cl…

使用 pytest-mock 进行 Python 高级单元测试与模拟

一、单元测试与模拟的意义 在软件开发中,单元测试用于验证代码逻辑的正确性。但实际项目中,代码常依赖外部服务(如数据库、API、文件系统)。直接测试这些依赖会导致: 测试速度变慢测试结果不可控产生副作用(如真实发送邮件)模拟(Mocking) 技术通过创建虚拟对象替代真…

(八)趣学设计模式 之 装饰器模式!

目录 一、 啥是装饰器模式&#xff1f;二、 为什么要用装饰器模式&#xff1f;三、 装饰器模式的实现方式四、 装饰器模式的优缺点五、 装饰器模式的应用场景六、 装饰器模式 vs 代理模式七、 总结 &#x1f31f;我的其他文章也讲解的比较有趣&#x1f601;&#xff0c;如果喜欢…

AI提示词的种类与适合的任务

以下是提示词的主要种类及其适用任务&#xff0c;基于大模型特性与最佳实践总结&#xff1a; 一、基础提示词 零样本提示&#xff08;Zero-shot Prompting&#xff09; 形式&#xff1a;直接输入任务指令&#xff0c;不提供示例&#xff08;如“翻译以下句子&#xff1a;Hello …