二进制转化为16进制
这道题目是32位的数,二进制32位,从右到左的方向为低位到高位,每4位为一组,通过这个公式
(nums>>(4×i)) & 0xf
将这4位转化为对应的16进制数(取值范围为0到15(即16进制的f))
对于负整数,由于最高位一定不是 0,因此不会出现前导零。对于零和正整数,可能出现前导零。避免前导零的做法如下:
如果 num=0
num=0,则直接返回 0
如果 num>0
num>0,则在遍历每一组的值时,从第一个不是 0 的值开始拼接成十六进制数。
完整代码
func toHex(num int) string {
if num == 0 {
return "0"
}
sb := &strings.Builder{}
for i := 7; i >= 0; i-- {
val := num >> (4 * i) & 0xf
if val > 0 || sb.Len() > 0 {
var digit byte
if val < 10 {
digit = '0' + byte(val)
} else {
digit = 'a' + byte(val-10)
}
sb.WriteByte(digit)
}
}
return sb.String()
}