当前位置: 首页 > wzjs >正文

政协网站法治建设国内最新新闻事件今天

政协网站法治建设,国内最新新闻事件今天,wordpress的seo如何写关键词,哪些平台可以建立网站题目 思路 首先我们先看一下格雷编码的一些情况,为了一会方便理解,我们看它的二进制情况。 当n1时,输出[0,1] 当n2时,输出[00,01,11,10] 当n3时,输出[000, 001, 011, 010, 110, 111, 101, 100] 我们可…

题目

思路

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

当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.dtcms.com/wzjs/248126.html

相关文章:

  • 高校网站集群平台子站开发百度认证平台
  • 服务网站建设的公司免费网站建站页面
  • 网站制作计划友情链接百科
  • 四川省建设厅注册管理中心网站五年级下册数学优化设计答案
  • 仙居做网站网络营销的渠道
  • 第一次做网站做后感如何写市场调研报告
  • 傻瓜一键自助建站系统杭州新站整站seo
  • 服装网站建设什么公司好口碑营销的特征
  • 做网站会不会亏本网站排名查询工具
  • win10系统做mac系统下载网站可口可乐营销策划方案
  • 为学校网站做网站推广策划书企业推广软文
  • 工业软件开发技术百度整站优化
  • 那可以做网站百度商业平台
  • 怎么做网站用dreamwer三门峡网站seo
  • e福州怎么代缴医保灰色词seo推广
  • 数字域名做网站附近的计算机培训班
  • 广州免费钓鱼地点50个优化推荐
  • 电子商务与网站建设报告百度知道登录
  • 做网站能用ai做吗百度app下载
  • 玛沁县wap网站建设公司seo顾问收费
  • java 网站开发 好书首页关键词排名优化
  • 做网站需要vps吗百度经验官方网站登录入口
  • 济南网站建设维护接推广app任务的平台
  • 做网站一年要多少钱优化大师绿色版
  • 帝国cms手机游戏应用网站模板如何创建一个网页
  • 网站独享ip哪有卖的老司机们用的关键词有哪些
  • 聊城有制作网站的吗seo优化方法网站快速排名推广渠道
  • 坊网站建设seo技术外包
  • 海南的网站建设公司电工培训机构
  • 怎么做网站排名优化seo做得比较好的公司