java 十进制转为任意进制方法
public class BinaryTest {
//设置字符数组
//可以添加任意不重复字符,提高能转换的进制的上限
static char chs[] = new char[36];
static {
for(int i = 0; i < 10 ; i++) {
chs[i] = (char)('0' + i);
}
for(int i = 10; i < chs.length; i++) {
chs[i] = (char)('A' + (i - 10));
}
}
/**
* 转换方法
* @param num 元数据字符串
* @param fromRadix 元数据的进制类型
* @param toRadix 目标进制类型
* @return
*/
static String transRadix(String num, int fromRadix, int toRadix) {
int number = Integer.valueOf(num, fromRadix);
StringBuilder sb = new StringBuilder();
while (number != 0) {
sb.append(chs[number%toRadix]);
number = number / toRadix;
}
return sb.reverse().toString();
}
//测试
public static void main(String[] args) {
System.out.println(transRadix("YGL", 36, 35));
}
}
例题编写程序实现将任意10进制正小数m转换成n进制的正小数,小数点后保留10位小数。
解答要求
时间限制:1000ms, 内存限制:64MB
输入包含两个数m,n,用空格隔开。输入包含多组测试,当m,n都为0时输入结束。
Limits:
0.0000009<m<1
1<n<10
输出10进制正小数m的n进制小数。结果保留10位小数。
样例
输入样例 1
0.795 3
0 0
输出样例 1
0.2101101122
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sr = new Scanner(System.in);
StringBuffer buff = new StringBuffer();
while (sr.hasNext()) {
buff.append("0.");
double a = sr.nextDouble();
int b = sr.nextInt();
if (a == 0 && b == 0) {
break;
}
//十进制小数a*要转换的进制b,取得到的结果的整数部分,正序拼接,就得到了小数点后面的小数部分。
for (int i = 0; i < 10; i ++){
a = (a - (int)a) * b;
buff.append((int)a);
}
System.out.println(buff);
buff.setLength(0);
}
}
}