码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2017-03-12 21:04:06      阅读:295      评论:0      收藏:0      [点我收藏+]

标签:put   out   while   2.0   strlen   color   tchar   des   i++   

基础练习 十六进制转八进制  
时间限制:1.0s   内存限制:512.0MB
      
问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

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

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

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

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

  提示
  先将十六进制数转换成某进制数,再由某进制数转换成八进制。
#include <iostream>
#include <cstdio>
#include <vector>
#include <queue>
#include <map>
#include <stack>
#include <cstring>
#include <algorithm>
#include <cstdlib>
#define FOR(i,x,n) for(int i=x;i<n;i++)
#define ll long long int
#define INF 0x3f3f3f3f
#define MOD 1000000007
#define MAX_N 50005

using namespace std;

map<char,string > ma1;
map<string,char > ma2;
char a[100005];
int two[400005];
char eight[200000];
int couEight=0;

void sett(){
    ma1[0]="0000";
    ma1[1]="0001";
    ma1[2]="0010";
    ma1[3]="0011";
    ma1[4]="0100";
    ma1[5]="0101";
    ma1[6]="0110";
    ma1[7]="0111";
    ma1[8]="1000";
    ma1[9]="1001";
    ma1[A]="1010";
    ma1[B]="1011";
    ma1[C]="1100";
    ma1[D]="1101";
    ma1[E]="1110";
    ma1[F]="1111";

    ma2["000"]=0;
    ma2["001"]=1;
    ma2["010"]=2;
    ma2["011"]=3;
    ma2["100"]=4;
    ma2["101"]=5;
    ma2["110"]=6;
    ma2["111"]=7;
}

int main()
{
    //freopen("input1.txt", "r", stdin);
    //freopen("data.out", "w", stdout);
    int N;
    sett();
    scanf("%d",&N);
    getchar();
    while(N--){
        scanf("%s",a);
        getchar();
        int cou=0;
        couEight=0;
        FOR(i,0,strlen(a)){
            string t1=ma1[a[i]];
            two[cou++]=t1[0]-0;
            two[cou++]=t1[1]-0;
            two[cou++]=t1[2]-0;
            two[cou++]=t1[3]-0;
        }
        int tt=cou%3;
        if(tt==0){
            couEight=0;
            for(int i=0;i<cou;i+=3){
                string t2="";
                t2+=two[i]+0;
                t2+=two[i+1]+0;
                t2+=two[i+2]+0;
                if(ma2[t2]==0){
                    if(i>0){
                        printf("%c",ma2[t2]);
                    }
                }else{
                    printf("%c",ma2[t2]);
                }
            }
            printf("\n");
        }else if(tt==1){
            couEight=0;
            if(two[0]==1){
                printf("1");
            }
            for(int i=1;i<cou;i+=3){
                string t3="";
                t3+=two[i]+0;
                t3+=two[i+1]+0;
                t3+=two[i+2]+0;
                if(ma2[t3]==0){
                    if(i>1){
                        printf("%c",ma2[t3]);
                    }
                }else{
                    printf("%c",ma2[t3]);
                }
            }
            printf("\n");
        }else if(tt==2){
            couEight=0;
            string t0="";
            t0+=0;
            t0+=two[0]+0;
            t0+=two[1]+0;
            if(ma2[t0]!=0){
                printf("%c",ma2[t0]);
            }

            for(int i=2;i<cou;i+=3){
                string t4="";
                t4+=two[i]+0;
                t4+=two[i+1]+0;
                t4+=two[i+2]+0;
                if(ma2[t4]==0){
                    if(i>2){
                        printf("%c",ma2[t4]);
                    }
                }else{
                    printf("%c",ma2[t4]);
                }
            }
            printf("\n");
        }

    }
    //fclose(stdin);
    //fclose(stdout);
    return 0;
}

 

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

标签:put   out   while   2.0   strlen   color   tchar   des   i++   

原文地址:http://www.cnblogs.com/TWS-YIFEI/p/6539108.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!