10进制转其他进制方法有几种,最好可以编写出通用的方法,只需要通过参数的形式调用即可。
方法一:利用StringBuffer,对于16进制需要进行是否 大于9的判断,大于9需要转化成对应的字母表示,通过(char)(temp - 10 + 'A')
- class ArrayTest5
- {
- public static void main(String[] args)
- {
- toHex(60);
- }
-
- /*
- 十进制-->十六进制,利用到StringBuffer。
- */
- public static void toHex(int num)
- {
- StringBuffer sb = new StringBuffer();
- for(int x=0; x<8; x++)
- {
- // 取低四位的值,15的二进制为0000 0000 0000 0000 0000 0000 0000 1111
- int temp = num & 15;
- // 如果大于9,对应相应的字母
- if(temp>9)
- sb.append((char)(temp-10+'A'));
- else
- // 把低四位的转化值添加到StringBuffer中
- sb.append(temp);
- //无符号右移4位
- num = num >>> 4;
- }
- // 反转输出结果
- System.out.println(sb.reverse());
- }
- /*
- 十进制-->二进制
- */
- public static void toBin(int num)
- {
- StringBuffer sb = new StringBuffer();
- while(num>0)
- {
- sb.append(num%2);
- num = num / 2;
- }
- System.out.println(sb.reverse());
- }
- }
复制代码 方法二:查表法。转化的数字通过数组来存储。
- class ArrayTest6
- {
- public static void main(String[] args)
- {
- //toHex(60);
- toBin(-6);
- }
- /*
- 十进制转化为二进制
- */
- public static void toBin(int num)
- {
- //定义二进制的表。
- char[] chs = {'0','1'};
- //定义一个临时存储容器。
- char[] arr = new char[32];
- //定义一个操作数组的指针
- int pos = arr.length;
- while(num!=0)
- {
- int temp = num & 1;
- arr[--pos] = chs[temp];
- num = num >>> 1;
- }
- for(int x=pos; x<arr.length; x++)
- {
- System.out.print(arr[x]);
- }
- }
- /*
- 0 1 2 3 4 5 6 7 8 9 A B C D E F ==十六进制中的元素。
- 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
- 查表法:将所有的元素临时存储起来,建立对应关系。
- 每一次&15后的值作为索引去查建立好的表,就可以找对应的元素。
- 这样比 -10+'a'简单的多。
- 这个表怎么建立呢?
- 可以通过数据的形式来定义。
- 终于出结果了,但是是反着的,想要正过来可以通过StringBuffer reverse功能来完成,
- 也可以使用已经学习过的容器:数组来完成存储。
- */
- public static void toHex(int num)
- {
- char[] chs = {'0','1','2','3'
- ,'4','5','6','7'
- ,'8','9','A','B'
- ,'C','D','E','F'};
-
- //定义一个临时容器。
- char[] arr = new char[8];
- int pos = arr.length;
- while(num!=0)
- {
- int temp = num & 15;
-
- arr[--pos] = chs[temp];
- num = num >>> 4;
- }
- System.out.println("pos="+pos);
- //存储数据的arr数组遍历。
- for(int x=pos;x<arr.length; x++)
- {
- System.out.print(arr[x]+",");
- }
- }
- }
复制代码 方法三:通用方法,通过参数传递决定转化进制。
- class ArrayTest7
- {
- public static void main(String[] args)
- {
- toBin(-6);
- //toHex(-60);
- //toOctal(60);
- //System.out.println(Integer.toBinaryString(6));
- System.out.println(Integer.toHexString(6));
- }
- /*
- 十进制-->二进制
- */
- public static void toBin(int num)
- {
- trans(num,1,1);
- }
- /*
- 十进制-->八进制
- */
- public static void toOctal(int num)
- {
- trans(num,7,3);
- }
- /*
- 十进制-->十六进制
- */
- public static void toHex(int num)
- {
- trans(num,15,4);
- }
- //通用的转换方法,传递的参数分别为:待转化数字、与运算的对应值、无符号右移的偏移量。
- //注意:这里的方法直接输出了转化后的值,返回值为void,而实际使用时大多需要范围值,范围值类型为String
- public static void trans(int num,int base,int offset)
- {
- //如果带转化数字为0,直接输出0
- if(num==0)
- {
- System.out.println(0);
- return ;
- }
- char[] chs = {'0','1','2','3'
- ,'4','5','6','7'
- ,'8','9','A','B'
- ,'C','D','E','F'};
- char[] arr = new char[32];
- int pos = arr.length;
- while(num!=0)
- {
- int temp = num & base;
- arr[--pos] = chs[temp];
- num = num >>> offset;
- }
- for(int x=pos; x<arr.length; x++)
- {
- System.out.print(arr[x]);
- }
- return ;
- }
- }
复制代码
|
|