5202 二进制转化为十六进制

5202 二进制转化为十六进制

Time Limit: 1000/1000MS (C++/Others) Memory Limit: 65536/65536KB (C++/Others)
Total Submissions: 332 Accepted Submissions: 64
Problem Description
输入一个2进制的数,要求输出该2进制数的16进制表示。在16进制的表示中,A-F表示10-15

Input
第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,包括一个以0和1组成的字符串,字符串长度至少是1,至多是10000。

Output
n行,每行输出对应一个输入。

Sample Input
2
100000
111
Sample Output
20
7

题解:
因为输入的二进制字符串最多有10000位,所以任何整型类型都放不下这个数(如果当成十进制先存入的话),所以只能把他当作字符串处理。
我们知道2进制转化16进制的方法是每四位2进制转化为一个16进制数,如果不够四位的话在左边补0。
不过我们在解题时使用的是把每取四位2进制数转化为一个10进制数,然后再转化为16进制。
如果最后取不够四位2进制的时候,我们无需补0,因为补0或者不补0都不会影响它的十进制数值大小。

#include <stdio.h>
#include <string.h>
int main()
{
	int n;
	scanf("%d",&n);
	int count = 0;
	int sum = 0;
	int k = 1;
	char num2[10010];//存放二进制字符串 
	char csix[5000];//存放16进制字符串 
	int j =0;
	while(n--)
	{
		memset(csix,0,sizeof(csix));
		memset(num2,0,sizeof(num2));
		scanf("%s",num2);
		for(int i=strlen(num2)-1;i>=0;i--)//这里要倒着取 
		{
			count++;
			if(count<=4)
			{
				sum += (num2[i]-'0') * k;
				k *= 2;
			}
			if(count==4||i==0)//i==0的作用:如果最后取不够四位也没关系,同样能算出它的十进制数大小 
			{
				csix[j++] = (sum>9?sum-10+'A':sum+'0'); 
				count = 0;
				k = 1;
				sum = 0;
			}
		}
		for(int k = strlen(csix)-1 ; k>=0 ; k--)//这里要倒着输出 
		{
			printf("%c",csix[k]);
		}
		j = 0;//记得给j置0 
		printf("\n");
	}
	return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值