描述
给定一个十进制数 M ,以及需要转换的进制数 N 。将十进制数 M 转化为 N 进制数。
当 N 大于 10 以后, 应在结果中使用大写字母表示大于 10 的一位,如 'A' 表示此位为 10 , 'B' 表示此位为 11 。
若 M 为负数,应在结果中保留负号。
示例1
输入:
7,2
复制返回值:
"111"
复制
备注:
M是32位整数,2<=N<=16.
除N取余,然后倒序排列,高位补零。
public String solve (int M, int N) {
// write code here
if(M == 0) return "0";
String s = "0123456789ABCDEF";
StringBuffer sb = new StringBuffer();
boolean f = false;
if(M < 0){
f = true;
M = -M;
}
while(M != 0){
sb.append(s.charAt(M%N));
M /= N;
}
if(f) sb.append("-");
return sb.reverse().toString();
}
}