zoukankan      html  css  js  c++  java
  • Leetcode 405.数字转化为十六进制数

    数字转化为十六进制数

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

    注意:

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

    示例 1:

    输入:

    26

    输出:

    "1a"

    示例 2:

    输入:

    -1

    输出:

    "ffffffff"

    第二种解法就是按位与来获取。既然是得到十六进制,那么每次与上0xF(二进制就是1111),得到一个值,然后数字向右移动4位,这里需要注意的是数字是有符号的,刚好可以利用Java提供的无符号移动>>>。完美!!!

     1 import java.util.ArrayList;
     2 import java.util.List;
     3 
     4 class Solution {
     5     char[] map = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
     6     public String toHex(int num) {
     7         if(num == 0) return "0";
     8         String result = "";
     9         while(num != 0){
    10             result = map[(num & 0xF)] + result;
    11             num = (num >>> 4);
    12         }
    13         return result;
    14     }
    15 }
  • 相关阅读:
    rpm 命令详解
    自动配置原理
    ssm框架整合
    单个库创建用户和权限
    Mysql5.7安装过程
    Eclipse和JDK版本以及位数对应关系
    DHCP服务器
    常用Dos命令
    八、Linux上常用网络操作
    数据库分区表(转)
  • 原文地址:https://www.cnblogs.com/kexinxin/p/10236750.html
Copyright © 2011-2022 走看看