加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

go实现整型的二进制转化

发布时间:2020-12-14 05:12:03 所属栏目:大数据 来源:网络整理
导读:go中已经实现了int-bin的转化函数,我这里只是化过程逻辑的实现,至于原理我就假设大家都知道了 本案例只考虑 int-bin? 的转化 包含了正整数,负整数,0 的转化 ? package mainimport ( " fmt " " strconv " ) // bin表示转化后的位数 func convertToBin(n i

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,//1101
        convertToBin(22222,8),convertToBin(0,convertToBin(1,convertToBin(-5,convertToBin(-22222,)
}

结果 :

5     13      22222      0    1      -5    -22222
00000101
00001101 10101101100111 00000000 00000001 22222011 1010010011001

?

比如-22222的转化:

变为整数: 22222
bin: 10101101100111
~bin : 01010010011000
结果:1010010011001

?

比如-1的转化:

变为整数: 1
bin: 00000001
~bin : 22222110
结果:22222111

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读