蓝桥杯-十六进制转八进制(C语言)

蓝桥杯-十六进制转八进制(C语言)

未完成!

可以的话希望有哪位大佬帮忙看一下哪里出了问题
这里是一只在进阶的小菜鸡

尝试了几次,决定先放弃了,可能能力还不太够(菜)

思路

将十六进制转换成二进制,再将二进制转换成八进制
十六进制转二进制保存在一个数组中
数组中的0位恰好对应二进制转到八进制的第一组三个数里的第一个应为2的0次(使用pow()函数)
每三组输出一次结果
输出完之后再计算下一个数组中的数

问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
  输出n行,每行为输入对应的八进制正整数。
  【注意】
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。
样例输入
  2
  39
  123ABC
样例输出
  71
  4435274
  【提示】
  先将十六进制数转换成某进制数,再由某进制数转换成八进制

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
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<n;i++)
  scanf("%s",&a[i]);
 for(i=0;i<n;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;
}

最后输出总是零

发布了8 篇原创文章 · 获赞 0 · 访问量 53
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 游动-白 设计师: 上身试试

分享到微信朋友圈

×

扫一扫,手机浏览