返回介绍

solution / 0400-0499 / 0405.Convert a Number to Hexadecimal / README

发布于 2024-06-17 01:04:01 字数 3062 浏览 0 评论 0 收藏 0

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

English Version

题目描述

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

注意:

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

示例 1:

输入:
26

输出:
"1a"

示例 2:

输入:
-1

输出:
"ffffffff"

解法

方法一

class Solution:
  def toHex(self, num: int) -> str:
    if num == 0:
      return '0'
    chars = '0123456789abcdef'
    s = []
    for i in range(7, -1, -1):
      x = (num >> (4 * i)) & 0xF
      if s or x != 0:
        s.append(chars[x])
    return ''.join(s)
class Solution {
  public String toHex(int num) {
    if (num == 0) {
      return "0";
    }
    StringBuilder sb = new StringBuilder();
    while (num != 0) {
      int x = num & 15;
      if (x < 10) {
        sb.append(x);
      } else {
        sb.append((char) (x - 10 + 'a'));
      }
      num >>>= 4;
    }
    return sb.reverse().toString();
  }
}
class Solution {
public:
  string toHex(int num) {
    if (num == 0) return "0";
    string s = "";
    for (int i = 7; i >= 0; --i) {
      int x = (num >> (4 * i)) & 0xf;
      if (s.size() > 0 || x != 0) {
        char c = x < 10 ? (char) (x + '0') : (char) (x - 10 + 'a');
        s += c;
      }
    }
    return s;
  }
};
func toHex(num int) string {
  if num == 0 {
    return "0"
  }
  sb := &strings.Builder{}
  for i := 7; i >= 0; i-- {
    x := num >> (4 * i) & 0xf
    if x > 0 || sb.Len() > 0 {
      var c byte
      if x < 10 {
        c = '0' + byte(x)
      } else {
        c = 'a' + byte(x-10)
      }
      sb.WriteByte(c)
    }
  }
  return sb.String()
}

方法二

class Solution {
  public String toHex(int num) {
    if (num == 0) {
      return "0";
    }
    StringBuilder sb = new StringBuilder();
    for (int i = 7; i >= 0; --i) {
      int x = (num >> (4 * i)) & 0xf;
      if (sb.length() > 0 || x != 0) {
        char c = x < 10 ? (char) (x + '0') : (char) (x - 10 + 'a');
        sb.append(c);
      }
    }
    return sb.toString();
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文