日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

腾讯2016校招试题----------格雷码的实现

發布時間:2023/12/10 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 腾讯2016校招试题----------格雷码的实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
問題:產生n位元的所有格雷碼。
格雷碼(Gray Code)是一個數列集合,每個數使用二進位來表示,假設使用n位元來表示每個數字,任兩個數之間只有一個位元值不同。 例如以下為3位元的格雷碼:?000 001 011 010 110 111 101 100 。 如果要產生n位元的格雷碼,那么格雷碼的個數為2^n.
假設原始的值從0開始,格雷碼產生的規律是:第一步,改變最右邊的位元值;第二步,改變右起第一個為1的位元的左邊位元;第三步,第四步重復第一步和第二步,直到所有的格雷碼產生完畢(換句話說,已經走了(2^n) - 1 步)。
用一個例子來說明: 假設產生3位元的格雷碼,原始值位 000 第一步:改變最右邊的位元值: 001 第二步:改變右起第一個為1的位元的左邊位元: 011 第三步:改變最右邊的位元值: 010 第四步:改變右起第一個為1的位元的左邊位元: 110 第五步:改變最右邊的位元值: 111 第六步:改變右起第一個為1的位元的左邊位元: 101 第七步:改變最右邊的位元值: 100
如果按照這個規則來生成格雷碼,是沒有問題的,但是這樣做太復雜了。如果仔細觀察格雷碼的結構,我們會有以下發現: 1、除了最高位(左邊第一位),格雷碼的位元完全上下對稱(看下面列表)。比如第一個格雷碼與最后一個格雷碼對稱(除了第一位),第二個格雷碼與倒數第二個對稱,以此類推。 2、最小的重復單元是 0 , 1
000
001
011
010
110
111
101
100

所以,在實現的時候,我們完全可以利用遞歸,在每一層前面加上0或者1,然后就可以列出所有的格雷碼。 比如: 第一步:產生 0, 1 兩個字符串。 第二步:在第一步的基礎上,每一個字符串都加上0和1,但是每次只能加一個,所以得做兩次。這樣就變成了 00,01,11,10 (注意對稱)。 第三步:在第二步的基礎上,再給每個字符串都加上0和1,同樣,每次只能加一個,這樣就變成了 000,001,011,010,110,111,101,100。 好了,這樣就把3位元格雷碼生成好了。 如果要生成4位元格雷碼,我們只需要在3位元格雷碼上再加一層0,1就可以了:?0000,0001,0011,0010,0110,0111,0101,0100,1100,1101,1110,1010,0111,1001,1000.
也就是說,n位元格雷碼是基于n-1位元格雷碼產生的。
如果能夠理解上面的部分,下面部分的代碼實現就很容易理解了。 //格雷碼 #include <iostream> #include <vector> #include <string> #include <cmath> using namespace std;vector<string> GrayCode(int n) {// produce 2^n grade codesvector<string> graycode(int(pow(float(2.), n)));if (n == 1) {graycode[0] = "0";graycode[1] = "1";return graycode;}vector<string> last = GrayCode(n - 1);for (int i = 0; i < last.size(); i++) {graycode[i] = "0" + last[i];graycode[graycode.size() - i - 1] = "1" + last[i];}return graycode; } int main() {vector<string> graycode = GrayCode(4);for (auto x: graycode){cout << x << endl;}}
參考文獻: 1.格雷碼的實現 2.格雷碼(百度百科)

總結

以上是生活随笔為你收集整理的腾讯2016校招试题----------格雷码的实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日批在线观看视频 | av网站免费在线播放 | 神马午夜伦理 | 激情av| 99产精品成人啪免费网站 | 成人精品视频99在线观看免费 | 欧美视频一区二区三区四区 | 免费在线观看国产精品 | 乱子伦一区 | 超污视频软件 | 国产96在线 | 国模视频在线 | 久久黄色一级视频 | 91av在线免费视频 | 中文字幕第11页 | 亚洲乱熟女一区二区三区小说 | 性生交生活片1 | 成人免费av网站 | 中文字幕第五页 | 中文字幕一二 | 欧美黄色一级网站 | 精品婷婷色一区二区三区蜜桃 | 清冷学长被爆c躁到高潮失禁 | 日韩污视频在线观看 | 波多野结衣视频网址 | 女同av在线播放 | 高潮无码精品色欲av午夜福利 | 成人a在线观看 | 91丨九色丨蝌蚪丨丝袜 | 91中文字幕 | 精品国偷自产国产一区 | 性做久久久久久久免费看 | 四虎黄色影院 | 精品视频久久 | 男女污污网站 | 欧美疯狂做受xxxxx高潮 | 日韩欧美三级 | 激情一级片 | 国产91在线观看丝袜 | 久久网伊人 | 国产熟妇久久777777 | 久久国产精品综合 | 日韩天堂网 | 波多野结衣一区二区三区在线 | 亚洲一区二区人妻 | 国产精品亚洲αv天堂无码 伊人性视频 | 粉嫩av一区二区三区免费观看 | 久久无码精品丰满人妻 | 老色鬼av | 91精品国自产在线 | 久久综合激的五月天 | 中文字幕av一区二区三区 | 欧美丰满一区二区免费视频 | 在线观看污视频网站 | 美国三级视频 | 96精品视频在线观看 | 日本黄色动态图 | 激情小视频在线观看 | 精品无码一区二区三区爱欲 | 超碰成人福利 | 亚洲无卡视频 | 精品中文在线 | 成人ay | 黄色小视频在线免费观看 | 亚洲自拍偷拍一区二区三区 | 亚洲三级大片 | 丁香花电影高清在线阅读免费 | 国偷自产视频一区二区久 | 久久婷婷五月综合色吧 | 2019年中文字幕 | av最新| 日本japanese乳偷乱熟 | 男人添女人下部高潮全视频 | 国产小视频免费 | 麻豆国产尤物av尤物在线观看 | 亚洲国产av一区二区 | 成人国产精品视频 | 羞羞的视频在线观看 | 日韩欧美国产一区二区三区 | 好吊妞这里有精品 | 小情侣高清国产在线播放 | 女性裸体瑜伽无遮挡 | 欧美性猛交xxx乱久交 | a久久久久久 | 69av导航| 日韩毛片网站 | 国产亚洲精品美女久久久久 | 亚洲精品v日韩精品 | 亚洲欧美激情在线 | 在线中文天堂 | 欧美高清videos高潮hd | 日韩欧美电影一区二区三区 | 日本少妇激情视频 | 久久国产电影 | 中文字幕9 | 精品香蕉一区二区三区 | 精品久久久无码中文字幕边打电话 | 美国一区二区三区 | 欧美成人久久 |