LeetCode(top100)格雷编码

格雷编码

题目描述

格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个位数的差异。
给定一个代表编码总位数的非负整数 n,打印其格雷编码序列。即使有多个不同答案,你也只需要返回其中一种。
格雷编码序列必须以 0 开头。

题目分析
思路(一)

关键是要找到规律
n = 0, [0]
n = 1, [0,1] //新的元素1,为0+2^0
n = 2, [0,1,3,2] // 新的元素[3,2]为[0,1]->[1,0]后分别加上2^1
n = 3, [0,1,3,2,6,7,5,4] // 新的元素[6,7,5,4]为[0,1,3,2]->[2,3,1,0]后分别加上2^2

/** 
 @param {number} n 
* @return {number[]} 
*/
var grayCode = function(n) {
   let res=[0];
   let right;
   var i=1;
   while(i<=n){
   //在对上一步得到的结果反序操作之前,先对上一步的数组进行复制,保证res中保存的是正常顺序的上一步结果元素
      rev=res.slice(0).reverse();
      //反序后的数组进行遍历,对每个元素+2^(i-1),得到当前i下的新增数组
      right=rev.map(item=>item+Math.pow(2,i-1));
      //将新增数组放在上一步得到的数组res元素后面,得到当前的新数组,继续循环
      res=res.concat(right);
      i++;
    }
    return res;
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值