任意进制转换

package com.xjj.test;

public class BinaryTest {
    
    //设置字符数组
    //可以添加任意不重复字符,提高能转换的进制的上限
	//添加36进制
    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) {
    	// 转换为10进制
        int number = Integer.valueOf(num, fromRadix);		
        System.out.println("number: "+number);
        StringBuilder sb = new StringBuilder();
        // 除以该进制值然后取余,直到商为0
        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("123", 16, 8));
    }
}

 

你可能感兴趣的:(算法)