`
woxiaoe
  • 浏览: 276566 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

java实现的任意进制转换

阅读更多

package com.woxiaoe.algorithm;

import java.util.Stack;
public class Base {
	/**
	 * 将数转为任意进制
	 * @param num
	 * @param base
	 * @return
	 */
	public static String baseString(int num,int base){
		if(base > 16){
			throw new RuntimeException("进制数超出范围,base<=16");
		}
		StringBuffer str = new StringBuffer("");
		String digths = "0123456789ABCDEF";
		Stack<Character> s = new Stack<Character>();
		while(num != 0){
			s.push(digths.charAt(num%base));
			num/=base;
		}
		while(!s.isEmpty()){
			str.append(s.pop());
		}
		return str.toString();
	}
	/**
	 * 16进制内任意进制转换
	 * @param num
	 * @param srcBase
	 * @param destBase
	 * @return
	 */
	public static String baseNum(String num,int srcBase,int destBase){
		if(srcBase == destBase){
			return num;
		}
		String digths = "0123456789ABCDEF";
		char[] chars = num.toCharArray();
		int len = chars.length;
		if(destBase != 10){//目标进制不是十进制 先转化为十进制
			num = baseNum(num,srcBase,10);
		}else{
			int n = 0;
			for(int i = len - 1; i >=0; i--){
				n+=digths.indexOf(chars[i])*Math.pow(srcBase, len - i - 1);
			}
			return n + "";
		}
		return baseString(Integer.valueOf(num),destBase);
	}
}
 
0
1
分享到:
评论
3 楼 zlxzlxzlxzlxzlx 2014-09-04  
这不能算是任意进制之间的转换,只能算是 2、8、10、16 几个进制之间互换···
例如二十六进制、十二进制又该如何呢???
2 楼 woxiaoe 2010-05-30  
huxiaobo136 写道
在JavaTM 2 Platform Standard Ed. 5.0中
indexOf(int ch) 是:
          返回指定字符在此字符串中第一次出现处的索引。
可见,第46行无法处理有重复字符串digths 时的情况!!!!

digths = "0123456789ABCDEF";  里面没有重复的项,
1 楼 huxiaobo136 2010-05-30  
在JavaTM 2 Platform Standard Ed. 5.0中
indexOf(int ch) 是:
          返回指定字符在此字符串中第一次出现处的索引。
可见,第46行无法处理有重复字符串digths 时的情况!!!!

相关推荐

Global site tag (gtag.js) - Google Analytics