算法程序员算法提高之LeetCode刷题

LeetCode算法题-Convert a Number to

2019-01-03  本文已影响16人  程序员小川

这是悦乐书的第219次更新,第231篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第86题(顺位题号是405)。给定一个整数,写一个算法将其转换为十六进制。对于负整数,使用二进制补码方法。例如:

输入:26
输出:“1a”

输入:-1
输出:“ffffffff”

注意

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

直接使用包装类Integer的toHexString方法,将num转为16进制字符串。

public String toHex(int num) {
    return Integer.toHexString(num);
}

03 第二种解法

此解法的思路来自于String toHexString(int i)的源代码,先将16进制所用到的字符放入一个字符数组,从'0'到'f'依次排列,再定义一个字符串。先将num和15进行与(&)运算,与运算的规则是同1为1,即将num转为二进制数和二进制数1111做运算,得到的结果即为对应字符数组中的第几位字符,然后将num无符号右移4位,只要num不等于0,就一直循环计算。最后返回result。

核心思路是每次取出最右边的四位进行与运算。

public String toHex2(int num) {
    if (num == 0) {
        return "0";
    }
    char[] ch = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
    String result = "";
    while (num != 0) {
        result = ch[num&15] + result;
        num >>>= 4;
    }
    return result;
}

04 小结

算法专题目前已连续日更超过两个月,算法题文章86+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

上一篇下一篇

猜你喜欢

热点阅读