十六进制转八进制C语言实现

试题 基础练习 十六进制转八进制

问题描述

给定n个十六进制正整数,输出它们对应的八进制数。

输入格式

输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式

输出n行,每行为输入对应的八进制正整数。

【注意】
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入

2
39
123ABC

样例输出

71
4435274

提示

根据题目提示,可以先将十六进制的数值转化为二进制,再把相应的二进制转换为对应的八进制,在转化期间要注意二进制转八进制要从后往前每三位转化,不足的位置补零,最后将转化成的八进制前面的空位的‘0’消掉;

具体过程如下

#include
#include
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;
}

你可能感兴趣的:(蓝桥杯,c语言)