go實現整型的二進制轉化的方法

這篇文章主要介紹了go實現整型的二進制轉化的方法,本文給大家介紹的非常詳細,具有一定的參考借鑑價值 ,需要的朋友可以參考下

go中已經實現了int->bin的轉化函數,我這裏只是化過程邏輯的實現,至於原理我就假設大家都知道了

本案例只考慮  int->bin  的轉化

包含了正整數,負整數,0 的轉化

package main
import (
  "fmt"
  "strconv"
)
//bin表示轉化後的位數
func convertToBin(n int,bin int) string{
  var b string
  switch {
  case n==0:
    for i:=0;i<bin;i++{
      b+="0"
    }
  case n>0:
    //strcov.Itoa 將 1 轉爲 "1" , string(1)直接轉爲assic碼
    for ; n>0;n/=2{
      b=strconv.Itoa(n%2)+b
    }
    //加0
    j:=bin-len(b)
    for i:=0;i<j;i++{
      b="0"+b
    }
  case n<0:
    n=n*-1
    // fmt.Println("變爲整數:",n)
    s:=convertToBin(n,bin)
    // fmt.Println("bin:",s)
    //取反
    for i:=0;i<len(s);i++{
      if s[i:i+1]=="1"{
        b+="0"
      }else{
        b+="1"
      }
    }
    // fmt.Println("~bin :",b)
    //轉化爲整形,之後加1 這裏必須要64,否則在轉化過程中可能會超出範圍
    n,err :=strconv.ParseInt(b,2,64)
    if err!=nil{
      fmt.Println(err)
    }
    //轉爲bin
    //+1
    b=convertToBin(int(n+1),bin)
  }
  return b
}
func main(){
  fmt.Println(
    convertToBin(5,8), //101
    convertToBin(13,8), //1101
    convertToBin(11111,8),
    convertToBin(0,8),
    convertToBin(1,8),
    convertToBin(-5,8),
    convertToBin(-11111,8),
  )
}

結果 :

5     13      11111      0    1      -5    -11111
00000101 00001101 10101101100111 00000000 00000001 11111011 1010010011001

比如-11111的轉化:

變爲整數: 11111
bin: 10101101100111
~bin : 01010010011000
結果:1010010011001

比如-1的轉化:

變爲整數: 1
bin: 00000001
~bin : 11111110
結果:11111111

總結

以上所述是小編給大家介紹的go實現整型的二進制轉化的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對神馬文庫網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章