在二进制转换过程中,每四个二级制的位数是一个十六进制的位数,则每四个四个处理二进制的数,来表示十六进制上的每个位置上的数。(注意使用字符表示二进制的数字)
可以知道0001=1,0010=2,0011=3,0100=4......一直到1111=F
其中若是二进制数位数不满4的倍数,则处理成四的倍数
如七位数1001001——>01001001把前面少的位数补0即可,然后再四位一转换,
如四位1001 从右往左第一四位是1,第二三位是0,则1+0*2+0*4+1*8=9
#include<stdio.h>
void strrev(char *str);
int main()
{
int T;
scanf("%d",&T);
for(int z=0;z<T;z++)
{
getchar();
char str[1000];int i,j;
char bc[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
scanf("%s",str+1);//为了方便从str[1]开始输入
int t=strlen(str+1);
strrev(str+1); //二进制数预处理
while(t%4!=0) str[++t]='0';
strrev(str+1);
for(i=1;i<=t;i+=4)//进制转换,d<<=1相当于d=d*2
{int d=1,res=0;
for(j=i+3;j>=i;j--) {
if(str[j]=='1')res +=d;
d<<=1;
printf("%c",bc[res]);
}
}
printf("\n");
}return 0;
}//自己去写字符串反转函数
void strrev(char *str)
{
}
这篇博客介绍了如何用C语言将二进制数转换为十六进制。通过补零确保二进制数位数为4的倍数,然后按每四位一组进行转换,利用字符表示二进制数值并输出对应的十六进制字符。示例代码中展示了处理过程,包括字符串反转和进制转换的实现。
5166

被折叠的 条评论
为什么被折叠?



