2020-09-02java 十进制转为任意进制方法

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);
    }
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值