Leetcode 405、数字转换为十六进制数

Problem Source : https://leetcode-cn.com/problems/convert-a-number-to-hexadecimal/

Solution Source : https://github.com/hujingbo98/algorithm/blob/master/source/leetcode/0405_ConvertANumberToHexadecimal.cpp

405、数字转换为十六进制数

给定一个整数,编写一个算法将这个数转换为十六进制数。对于负整数,我们通常使用补码运算方法。

注意:
十六进制中所有字母(a-f)都必须是小写。
十六进制字符串中不能包含多余的前导零。如果要转化的数为0,那么以单个字符’0’来表示;
对于其他情况,十六进制字符串中的第一个字符将不会是0字符。
给定的数确保在32位有符号整数范围内。
不能使用任何由库提供的将数字直接转换或格式化为十六进制的方法。

示例 1:

输入:
26
输出:
"1a"

示例 2:

输入:
-1
输出:
"ffffffff"

方法一:位运算

题目要求将给定的整数 num 转换为十六进制数,负整数使用补码运算方法。

在补码运算中,最高位表示符号位,符号位是 0 表示正整数和零,符号位是 1 表示负整数。32 未有符号整数的二进制数是 32 位,由于一位十六进制数对应四位二进制数,因此32 位有符号整数的十六进制有 8 位。

将 num 的二进制数按照四位一组分成 8 组,依次将每一组转换为对应的十六进制数,即可得到 num 的十六进制数。

假设二进制数的 8 组从低位到高位依次是第 0 组到第 7 组,则对于第 i 组,可以通过 (num >> (4*i)) & 0xf 的到该组的值,其取值范围是 0 到 15(即十六进制的 f)。

将每一组的值转换为十六进制数的做法如下:

  • 对于 0 到 9,数字本身就是十六进制数。
  • 对于 10 到 15,将其转换为 a 到 f 中对应的字母。

对于负整数,由于最高位一定不是 0,因此不会出现前导零。对于零和正整数,可能出现前导零。避免签到零的做法如下:

  • 如果 num = 0,则直接返回 0。
  • 如果 num > 0,则在遍历每一组的值时,从第一个不是 0 的值开始十六进制数。

时间复杂度是 O(k),其中 k 是整数的十六进制数的位数,这道题中 k = 8。无论 num 的值是多少,都需要遍历 num 的十六进制数的全部位数。

空间复杂度是 O(k),需要存储 num 的十六进制表示中的除了前导零以外的全部位数。

string toHex(int num) {
    if (0 == num)
        return "0";

    string ans;
    for (int i = 7; i >= 0; --i) {
        int nbit = (num >> (i * 4)) & 0xf;
        if (ans.length() > 0 || nbit > 0) {
            char bit = nbit < 10 ? ('0' + nbit) : ('a' + nbit - 10);
            ans.push_back(bit);
        }
    }
    return ans;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值