【leetcode】405.数字转换为十六进制数js

碎碎念

前天熬的夜今天也是全还回来了好晕啊。。图书馆这两天空调开得也很大,平常都不带外套的今天都裹上了。

题目

十进制转n进制通用模板

javascript 复制代码
/**
 * @param {number} num
 * @param {number} base
 * @return {string}
 */
var convertToBaseN = function(num, base) {
  if (num === 0) return '0'
  const digits = '0123456789ABCDEF'
  let res = ''
  while (num > 0) {
    res = digits[num % base] + res
    num = Math.floor(num / base)
  }
  return res
};

本题思路

正数部分没什么好说的套模板就行了。

负数说要用补码,这就需要了解一下补码是怎么计算的了。手算的话可以看看下面两个方法:

  1. 符号位保持不变,将尾数按位取反后加1。
  1. 符号位保持不变,尾数自低位向高位,第一个1及其以前的各位0保持不变,其他位按位取反。

上面也算小复习了哈哈哈,但如果是在代码里呢?可以看下补码和真值的映射:

可以看到负数的真值加上2^{n}就可以。而这题数的范围是-2^{-31}~2^{31}-1,因此我们加上2^{32}之后按照正数的继续算就行。

代码

javascript 复制代码
/**
 * @param {number} num
 * @return {string}
 */
var toHex = function(num) {
    if (num === 0) return '0'
    const digit = '0123456789abcdef'
    let ans = ''
    if (num < 0) num += Math.pow(2, 32)
    while (num > 0) {
        ans = digit[num % 16] + ans
        num = Math.floor(num / 16)
    }
    return ans
};
相关推荐
专注VB编程开发20年2 小时前
AI 生成C# WinForm 窗体 = 目前就是垃圾
开发语言·人工智能·c#
cfm_29142 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
~小先生~2 小时前
Python从入门到放弃(一)
开发语言·python
许彰午2 小时前
17_synchronized关键字深度解析
java·开发语言
z落落2 小时前
C# 泛型接口和泛型类+泛型约束
开发语言·c#
阿正的梦工坊2 小时前
【Rust】02-变量、不可变性与基础类型
开发语言·后端·rust
阿正的梦工坊3 小时前
【Rust】08-集合类型、字符串与迭代器入门
开发语言·rust·c#
FuckPatience3 小时前
C# 使用泛型协变将派生类类型替换为基类类型
开发语言·c#
张忠琳3 小时前
【Go 1.26.4】(Part 1) Go 1.26.4 超深度源码分析 — 总体架构与模块全景
开发语言·golang