【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
};
相关推荐
铁皮饭盒7 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
小林ixn8 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
东风破_8 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦8 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript
不好听6139 小时前
JavaScript 的 this 到底指向谁?
javascript·面试
触底反弹9 小时前
🔥 2026 年爆火的 Harness Engineering 到底是什么?从原理到实战一文讲透
javascript·人工智能·程序员
mONESY9 小时前
一文搞定JavaScript不同场景中 this 的指向问题
javascript
用户298698530149 小时前
在 React 中使用 JavaScript 合并 Excel 文件
前端·javascript·react.js
大流星9 小时前
LangChainJs之基础模型(一)
javascript·langchain
橘子星9 小时前
JavaScript this 指向全解实战指南
前端·javascript