位运算相关的

二进制转化为16进制

参考lc题目

这道题目是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()
}
上一篇:C#获取当前路径的七种方法 【转载】


下一篇:Digital Roots