蓝桥杯-十六进制转八进制(C语言)
未完成!
可以的话希望有哪位大佬帮忙看一下哪里出了问题 这里是一只在进阶的小菜鸡
尝试了几次,决定先放弃了,可能能力还不太够(菜)
思路
将十六进制转换成二进制,再将二进制转换成八进制 十六进制转二进制保存在一个数组中 数组中的0位恰好对应二进制转到八进制的第一组三个数里的第一个应为2的0次(使用pow()函数) 每三组输出一次结果 输出完之后再计算下一个数组中的数
问题描述 给定n个十六进制正整数,输出它们对应的八进制数。 输入格式 输入的第一行为一个正整数n (1<=n<=10)。 接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。 输出格式 输出n行,每行为输入对应的八进制正整数。 【注意】 输入的十六进制数不会有前导0,比如012A。 输出的八进制数也不能有前导0。 样例输入 2 39 123ABC 样例输出 71 4435274 【提示】 先将十六进制数转换成某进制数,再由某进制数转换成八进制
#include
#include
#include
int b[100001];
int main()
{
int k,flag=3,f,n,i,j=0,h;
double sum=0;
char *a;
scanf("%d",&n);
a=(char *) malloc(n * sizeof(int));
for(i=0;i
scanf("%s",&a[i]);
for(i=0;i
{
while(a[i])
{
b[j]=a[i]%2;
a[i]/=2;
}
if((j+1)%3!=0)
{
f=3-(j+1)%3;
while(f--)
b[++j]=0;
}
for(k=0;k<=j;)
{
sum=0;
for(h=0;h<=2;h++)
{
sum=sum+b[k]*pow(2,h);
k++;
}
printf("%d",sum);
}
printf("\n");
}
return 0;
}