常用算法之进制转换

来源:互联网 发布:linux安装ssh 编辑:程序博客网 时间:2024/05/16 01:24

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

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

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

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

代码:

[java] view plaincopy
  1. public class Base {     
  2.         /**   
  3.          * 将数转为任意进制   
  4.          * @param num   
  5.          * @param base   
  6.          * @return   
  7.          */    
  8.         public String baseString(int num,int base){     
  9.             if(base > 16){     
  10.                 throw new RuntimeException("进制数超出范围,base<=16");     
  11.             }     
  12.             StringBuffer str = new StringBuffer("");     
  13.             String digths = "0123456789ABCDEF";     
  14.             Stack<Character> s = new Stack<Character>();     
  15.             while(num != 0){     
  16.                 s.push(digths.charAt(num%base));     
  17.                 num/=base;     
  18.             }     
  19.             while(!s.isEmpty()){     
  20.                 str.append(s.pop());     
  21.             }     
  22.             return str.toString();     
  23.         }     
  24.         /**   
  25.          * 16进制内任意进制转换   
  26.          * @param num   
  27.          * @param srcBase   
  28.          * @param destBase   
  29.          * @return   
  30.          */    
  31.         public String baseNum(String num,int srcBase,int destBase){     
  32.             if(srcBase == destBase){     
  33.                 return num;     
  34.             }     
  35.             String digths = "0123456789ABCDEF";     
  36.             char[] chars = num.toCharArray();     
  37.             int len = chars.length;     
  38.             if(destBase != 10){//目标进制不是十进制 先转化为十进制     
  39.                 num = baseNum(num,srcBase,10);     
  40.             }else{     
  41.                 int n = 0;     
  42.                 for(int i = len - 1; i >=0; i--){     
  43.                     n+=digths.indexOf(chars[i])*Math.pow(srcBase, len - i - 1);     
  44.                 }     
  45.                 return n + "";     
  46.             }     
  47.             return baseString(Integer.valueOf(num),destBase);     
  48.         }     
  49.     }    

原创粉丝点击