给定一个十进制数 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
};