日韩性视频-久久久蜜桃-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第一福利大全导航 | 亚洲国产欧美日韩 | 色香蕉av| 免费在线视频一区 | 免费三片在线播放 | 操操操影院 | 北条麻妃在线一区 | 在线看黄色的网站 | 亚洲爱视频| 99国产在线 | 精品国产乱码久久久久久浪潮 | 久久99色 | 波多野结衣一二三四区 | 日本一区二区视频在线播放 | 欧美精品一区二 | 欧美日韩高清不卡 | 69日影院| 麻豆影音 | 一级片大片 | 日日碰狠狠添天天爽无码av | 毛片123 | 先锋影音av资源网 | 人人爱爱| 色妻av| 亚洲性图一区二区 | 国产一及毛片 | 国产片网站 | 日本人妻熟妇久久久久久 | 黄色视屏在线免费观看 | 国产一区二区三区日韩 | 亚洲国产精品久久AV | 欧美大片xxxx | 26uuu成人网 国产精品久久久久久久久久直播 | 久久久久久国产精品免费免费 | 伦理久久| 国产一级黄色大片 | 日韩一区二区三区四区五区六区 | 在线天堂中文字幕 | 黄色尤物视频 | 天天影视色 | 蜜桃视频色 | 激情av小说 | 久久片| 日韩不卡 | 久久欧 | 一区二区日本 | 最好看十大无码av | 你懂的网站在线 | 成人在线你懂的 | 日韩精品中文字幕一区二区三区 | 日韩三级a| 91久久人澡人人添人人爽欧美 | 人人妻人人爽一区二区三区 | 日日碰狠狠添天天爽无码 | 亚洲性免费 | 少妇的被肉日常np | 牲欲强的熟妇农村老妇女视频 | 嫩草影院黄 | 精品国产91久久久久久 | 日日日夜夜操 | 美女扒开尿口来摸 | 成人精品综合 | 亚洲成人高清在线观看 | 五月婷婷六月丁香 | 亚洲无码久久久久久久 | 亚洲自拍色图 | 国产激情一区 | 无套在线观看 | 性生活视屏 | 熟女人妻一区二区三区免费看 | 金瓶风月在线 | 国产人妻人伦精品1国产丝袜 | 北条麻妃久久 | av在线导航 | 欧美老熟妇乱xxxxx | 亚洲成人激情av | 在线观看 一区 | 精品二区在线观看 | 中文字幕三级 | 99色婷婷 | 午夜精品国产精品大乳美女 | 麻豆av电影网 | 在线不卡日韩 | 国产牛牛 | 国产在线999 | 国产精品福利网站 | 久久亚洲高清 | 国产成人精品一区二 | 日本中文字幕成人 | 中文字幕人妻精品一区 | 久久精品五月天 | 公侵犯人妻一区二区 | 国产精品情侣 | 午夜免费视频网站 | 中文字幕一区二区不卡 |