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


    基础练习 十六进制转八进制  
    时间限制: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("
    ");
            }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("
    ");
            }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("
    ");
            }
    
        }
        //fclose(stdin);
        //fclose(stdout);
        return 0;
    }
  • 相关阅读:
    Linux搭建iscsi服务,客户端(Linux&Win XP)挂载使用
    SecucreCRT安装与破解
    最全的HCIA-R&S实验笔记
    AtCoder Grand Contest 036
    Comet OJ CCPC-Wannafly & Comet OJ 夏季欢乐赛(2019)
    2019慈溪集训小记
    Codeforces Round #573 (Div. 1)
    Comet OJ
    Codeforces Round #576 (Div. 1)
    Codechef August Challenge 2019 Division 2
  • 原文地址:https://www.cnblogs.com/TWS-YIFEI/p/6539108.html
Copyright © 2020-2023  润新知