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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

生成格雷码

發布時間:2023/12/20 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 生成格雷码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

生成格雷碼

題目

在一組數的編碼中,若任意兩個相鄰的代碼只有一位二進制數不同,則稱這種編碼為格雷碼(Gray Code)請編寫一個函數,使用遞歸的方法生成N位的格雷碼。

給定一個整數n,請返回n位的格雷碼,順序為從0開始。

測試樣例:
1
返回:[“0”,“1”]

什么是格雷碼

格雷碼任意兩個相鄰的代碼只有一位二進制數不同,例如下圖

格雷碼屬于可靠性編碼,是一種錯誤最小化的編碼方式。因為,雖然自然二進制碼可以直接由數/模轉換器轉換成模擬信號,但在某些情況,例如從十進制的3轉換為4時二進制碼的每一位都要變,能使數字電路產生很大的尖峰電流脈沖。而格雷碼則沒有這一缺點,它在相鄰位間轉換時,只有一位產生變化。它大大地減少了由一個狀態到下一個狀態時邏輯的混淆。

遞歸生成碼表

這種方法基于格雷碼是反射碼的事實,利用遞歸的如下規則來構造:

  • 1位格雷碼有兩個碼字
  • (n+1)位格雷碼中的前2n個碼字等于n位格雷碼的碼字,按順序書寫,加前綴0
  • (n+1)位格雷碼中的后2n個碼字等于n位格雷碼的碼字,按逆序書寫,加前綴1
  • n+1位格雷碼的集合 = n位格雷碼集合(順序)加前綴0 + n位格雷碼集合(逆序)加前綴1
  • import java.util.*;public class GrayCode {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n= sc.nextInt();System.out.println(Arrays.toString(getGray(n)));}private static String[] getGray(int n) {if(n == 1){return new String[]{"0","1"};}else{String[] temp = getGray(n-1);String[] result= new String[temp.length*2];for(int i = 0; i < temp.length;i++)result[i] = "0"+temp[i];int i,j;j = temp.length - 1;for( i = 0; i < temp.length && j>= 0;i++,j--)result[i+temp.length] = "1"+temp[j];return result;}} }

    總結

    以上是生活随笔為你收集整理的生成格雷码的全部內容,希望文章能夠幫你解決所遇到的問題。

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