十进制和二进制
//
十进制-->二进制
public static void toBin( int num)
{
StringBuffer sb = new StringBuffer();
while(num>0)
{
// System.out.println(num%2);
sb.append(num%2);
num = num / 2;
}
System.out.println(sb.reverse());
}
public static void toBin( int num)
{
StringBuffer sb = new StringBuffer();
while(num>0)
{
// System.out.println(num%2);
sb.append(num%2);
num = num / 2;
}
System.out.println(sb.reverse());
}
十进制和十六进制
View Code
//
十进制-->十六进制
public static void toHex( int num)
{
StringBuffer sb = new StringBuffer();
for( int x=0; x<8; x++)
{
int temp = num & 15;
if(temp >9)
{
// System.out.println((char)(temp-10 +'A'));
sb.append(( char)(temp-10 +'A'));
}
else
{
// System.out.println(temp);
sb.append(temp);
}
num = num >>> 4;
}
System.out.println(sb.reverse());
public static void toHex( int num)
{
StringBuffer sb = new StringBuffer();
for( int x=0; x<8; x++)
{
int temp = num & 15;
if(temp >9)
{
// System.out.println((char)(temp-10 +'A'));
sb.append(( char)(temp-10 +'A'));
}
else
{
// System.out.println(temp);
sb.append(temp);
}
num = num >>> 4;
}
System.out.println(sb.reverse());
十进制转十六进制(查表法)
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'简单的多。
这个表怎么建立呢?
可以通过数组的形式来定义。
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;
// System.out.println(chs[temp]);
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]+",");
}
}
{
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;
// System.out.println(chs[temp]);
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]+",");
}
}
public
static
void toBin_2(
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]);
}
}
{
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]);
}
}
进制转换优化
class ArrayTest7
{
public static void main(String[] args)
{
// toBin(-6);
// toHex(-60);
// toBa(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 toBa( int num)
{
trans(num,7,3);
}
/*
十进制转十六进制
*/
public static void toHex( int num)
{
trans(num,15,4);
}
public static void trans( int num, int base, int offset)
{
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 ;
}
}
{
public static void main(String[] args)
{
// toBin(-6);
// toHex(-60);
// toBa(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 toBa( int num)
{
trans(num,7,3);
}
/*
十进制转十六进制
*/
public static void toHex( int num)
{
trans(num,15,4);
}
public static void trans( int num, int base, int offset)
{
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 ;
}
}