您的位置:首页 > 其它

进制转换(美化版)

2012-04-19 23:24 204 查看
//查表法
class ArrayTest2
{
/*
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后的值作为索引去查建立好的表,就可以找对应的元素。
*/
public static void toHex(int num)
{
System.out.print(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;
}
for(int x = pos; x < arr.length; x++)
{
System.out.print(arr[x]);
}
System.out.println();
}

//十进制-->二进制
public static void toBin(int num)
{
System.out.print(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]);
}
System.out.println();
}

public static void main(String[] args)
{
toHex(60);
toHex(-60);
toBin(6);
toBin(-6);
}
}




上机感言:这个程序既可以实现正数的转换还可以实现负数的转换,而上一个则不能实现负数的转换,有些函数可以直接用,比如排序函数,即使你不会排序,你也可以排序,直接调用就可以
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  存储 string class c