给定一个十进制数 M ,以及需要转换的进制数 N 。将十进制数 M 转化为 N 进制数。
当 N 大于 10 以后, 应在结果中使用大写字母表示大于 10 的一位,如 'A' 表示此位为 10 , 'B' 表示此位为 11 。
若 M 为负数,应在结果中保留负号。
数据范围:
要求:空间复杂度
,时间复杂度
7,2
"111"
10,16
"A"
function solve( M , N ) { // write code here return M.toString(N).toUpperCase() }
/** * 进制转换 * @param M int整型 给定整数 * @param N int整型 转换到的进制 * @return string字符串 */ function solve( M , N ) { // write code here let str = ''; let absn = Math.abs(M); const keyMap = {10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F'}; while(absn > 0) { let s = absn%N; if(keyMap[s]) { str += keyMap[s]; } else { str += s; } absn = Math.floor(absn/N) } const dest = str.split('').reverse().join('') || '0'; return M >= 0 ? dest : '-' + dest ; } module.exports = { solve : solve };