常用算法之进制转换

进制转换在实际的编程中会经常使用,尤其是二进制的数。

先看一个可以在16进制内任意转换的算法,实际就是:

(1)10进制转为其它进制,使用辗转相除,逆序取余

(2)其它进制转为十进制,则按权展开

代码:

public class Base {   
	    /**  
	     * 将数转为任意进制  
	     * @param num  
	     * @param base  
	     * @return  
	     */  
	    public 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 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
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值