面试中经常有相关进制转换的面试题,工作中也涉及到了。比如数据传输的时候就需要转换成16进制,不过那是字符串,我们这里说整型。
#include<stdio.h>
#include<stdlib.h>
char CODE[]="123456789ABCDEF";
void toHex(int a)
{
int high,low,i=0,result;
char str[10];
if(a <= 0 || a > 255)
exit(0);
high=a >> 4; //取二进制位的前4位
low=a & 15; //取二进制位的后4位
str[i++]=CODE[high-1];
str[i++]=CODE[low-1];
str[i]='\0';
printf("str=%s\n",str);
}
int main()
{
int a=26;
toHex(a);
return 0;
}
打印:str=1A
首先是十进制转换为2进制,这个2进制一定是4的整数倍。将这组二进制按4个位进行划分,可以划分为n个组,每个组对应的值就是十六进制各个位对应的值。上述代码只考虑了8个二进制位的情况
比如:26 ,其二进制为:0001 1010 ,左边4个二进制位的值是1,右边4个二进制的值是10,对应就是A,所以26的十六进制数为1A 。
版权声明:本文为ma2595162349原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。