粥里有勺糖

vuePress-theme-reco 粥里有勺糖    2018 - 2023
粥里有勺糖 粥里有勺糖

Choose mode

  • dark
  • auto
  • light
关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
author-avatar

粥里有勺糖

285

文章

40

标签

关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
  • Code

    • 手撕代码
    • 防抖与节流实现
    • 模式串匹配
    • 居中
    • 定时器实现
    • 任意进制转换
    • 二叉树的遍历

任意进制转换

vuePress-theme-reco 粥里有勺糖    2018 - 2023

任意进制转换

粥里有勺糖 2020-05-03 面试手撕代码

# 任意进制转换

/**
 * 其他进制转10进制
 * @param {Number} num 
 * @param {Number} n 
 */
function otherToTen(num, n) {
    let sum = 0;
    let a = 'a'.charCodeAt()
    let zero = '0'.charCodeAt()
    for (let i = num.length - 1; i >= 0; i--) {
        let char = num.slice(i, i + 1)
        let az = /[a-z]/
        let t = 0
        if (az.test(char)) {
            t = char.charCodeAt() - a + 10
        } else {
            t = char.charCodeAt() - zero
        }
        if (t >= n) {
            throw new Error('error num')
        }
        sum += ~~(t * Math.pow(n, num.length - 1 - i))
    }
    return sum
}
/**
 * 十进制转其它进制
 * @param {Number} num 
 * @param {Number} n 
 */
function tenToOther(num, n) {
    let zero = '0'.charCodeAt()
    let a = 'a'.charCodeAt()
    let res = ''
    while (num) {
        let t = num % n
        if (t >= 0 && t < 10) {
            res = String.fromCharCode(t + zero) + res;
        } else {
            t -= 10
            res = String.fromCharCode(t + a) + res;
        }
        num /= n
        num = ~~num
    }
    return res
}

console.log(otherToTen('1001011', 2)); // 75
console.log(tenToOther('9999', 16)); // 270f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
Edit this page (opens new window)
Last Updated: 2022/5/15 12:46:34