试题 基础练习 十六进制转八进制
问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】
输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2
39
123ABC
样例输出
71
4435274
提示
根据题目提示,可以先将十六进制的数值转化为二进制,再把相应的二进制转换为对应的八进制,在转化期间要注意二进制转八进制要从后往前每三位转化,不足的位置补零,最后将转化成的八进制前面的空位的‘0’消掉;
具体过程如下
#include<stdio.h>
#include<string.h>
int main()
{
char h[1000],b[1000],e[1000];
int n;
scanf("%d",&n);
while(n--)
{
scanf("%s",h);
int i,len=0;
//将16进制转换为二进制,从后向前展开
for(i=strlen(h)-1;i>=0;i--)
{
int v;
if(h[i]>='0'&&h[i]<='9')
{
v=h[i]-'0';
}
else
{
v=h[i]-'A'+10;
}
for(int j=0;j<4;j++)
{
b[len++]=v%2+'0';
v/=2;
}
}
b[len]='\0';
printf("%s\n",b);
//输出中间二进制表示(逆序)
int x=0,cnt=1;
int l=0;
for(i=0;i<len;i++)
{
//每三位二进制转化为一位八进制,不足三位补零
if(cnt==4||i==len-1)
{
x=cnt*(b[i]-'0')+x;
cnt=1;
e[l++]=x+'0';
x=0;
}
else
{
x=cnt*(b[i]-'0')+x;
cnt=cnt*2;
}
}
i=l-1;
while(i>=0&&e[i]=='0')
i--;
if(i<0)
printf("0");
else
{
for(;i>=0;i--)
printf("%c",e[i]);
}
printf("\n");
}
return 0;
}