每日刷题(五十三)
BASIC-12、十六进制转八进制
之前我也出过关于这个题的题解博客,这次我换一种方法,就是把十六进制每个位转化为十进制数,然后再将十进制数转化为二进制数,再由二进制数转化为八进制数。
我们知道八进制数是3个2为一个组合,十六进制数是4个2为一个组合。
由于内存不能开太大了,要不然会溢出,所以我设了两个数组,一个字符数组用来记录输入的字符串,另一个int型数组的长度需要大一些,因为我需要存放二进制数。当存好二进制数后我们需要每三个转换为八进制数,需要用到sum来记录八进制数,再把其他数字标记为-1,目的是为了之后输出方便。
详细代码如下:
#include<stdio.h>
#include<string.h>
#include<math.h>
int main()
{
int n;
scanf("%d", &n);
int v = 0;
while(n)
{
char a[100000]; //用来存放十六进制数
int b[400000]; //用来存放二进制数
scanf("%s", a);
memset(b, 0, sizeof(b));
int l = 0; //二进制总长度
int i = strlen(a);
int cnt = 0;
for(i -= 1; i >= 0; i--)
{
if(a[i] >= 'A' && a[i] <= 'F')
cnt = a[i] - 'A' + 10; //先转化为十进制
else if(a[i] >= '0' && a[i] <= '9')
cnt = a[i] - 48;
int j;
int t = 0;
for(j = 0; j < 4; j++) //再转化为二进制
{
t = cnt % 2;
cnt /= 2;
b[l++] = t;
}
}
v = l - 1;
int flag = 0;
int sum = 0;
for(l = 0; l <= v; l++) //再由二进制转化为八进制
{
if(flag < 3)
{
sum += pow(2, flag) * b[l];
b[l] = -1;
flag++;
}
else if(flag == 3)
{
l -= 1;
b[l] = sum;
sum = 0;
flag = 0;
}
if(l == v)
{
b[l] = sum;
}
}
int cv = v;
for(; cv >= 0; cv--)
{
if(b[cv] == -1)
continue;
else
printf("%d", b[cv]);
}
printf("\n");
n--;
}
return 0;
}
部分运行代码如下:
我真的要吐槽一下蓝桥杯这题的测试数据,从第八个开始往后走,部分数据根本输不进去了,我怀疑gets()函数有局限性