描述输入一个2进制的数,要求输出该2进制数的16进制表示。
在16进制的表示中,A-F表示10-15
输入第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,包括一个以0和1组成的字符串,字符串长度至少是1,至多是10000输出n行,每行输出对应一个输入。样例输入
2
100000
111
样例输出
20
7
#include<stdio.h>
#include<string.h>
#include<math.h>
int main(){char input[10005];
int i,temp,length,Case;
scanf("%d",&Case);
while(Case--){
scanf("%s",input);
length=strlen(input);
temp=length%4;
int sum=0;
if(temp){
for(i=0;i<temp;i++)
sum+=(input[i]-'0')*pow(2,temp-1-i);
printf("%X",sum);}
for(i=temp;i<length;i+=4)
printf("%X",(input[i]-'0')*8+(input[i+1]-'0')*4+(input[i+2]-'0')*2+(input[i+3]-'0'));
printf("\n");}
return 0;}