BASIC-12 十六进制转八进制

BASIC-12 十六进制转八进制

题目

资源限制

时间限制:1.0s 内存限制:512.0MB

问题描述

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

输入格式

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

输出格式

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

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

样例输入

2
39
123ABC

样例输出

71
4435274

【提示】先将十六进制数转换成某进制数,再由某进制数转换成八进制。

题解

import java.util.Scanner;

public class BASIC_12 {

    public static String[] toBinary(String[] source) {
        String[] result = new String[source.length];
        char[] temp;
        StringBuffer resultTmp = new StringBuffer("");
        for (int i = 0; i < source.length; i++) {
            temp = source[i].toCharArray();
            for (int j = 0; j < temp.length; j++) {
                switch (temp[j]) {
                    case '0':resultTmp.append("0000");break;
                    case '1':resultTmp.append("0001");break;
                    case '2':resultTmp.append("0010");break;
                    case '3':resultTmp.append("0011");break;
                    case '4':resultTmp.append("0100");break;
                    case '5':resultTmp.append("0101");break;
                    case '6':resultTmp.append("0110");break;
                    case '7':resultTmp.append("0111");break;
                    case '8':resultTmp.append("1000");break;
                    case '9':resultTmp.append("1001");break;
                    case 'A':resultTmp.append("1010");break;
                    case 'B':resultTmp.append("1011");break;
                    case 'C':resultTmp.append("1100");break;
                    case 'D':resultTmp.append("1101");break;
                    case 'E':resultTmp.append("1110");break;
                    case 'F':resultTmp.append("1111");break;
                    default:break;

                }
            }
            result[i] = resultTmp.toString();
            resultTmp = null;
            resultTmp = new StringBuffer();
        }
        return result;
    }

    public static String[] toOctal(String[] binary) {
        String[] result = new String[binary.length];
        StringBuffer resultTmp = new StringBuffer("");
        int oldIndex = 0;
        for (int i = 0; i < binary.length; i++, oldIndex = 0) {
            if (binary[i].length() % 3 == 1) {
                binary[i] = "00" + binary[i];
            } else if (binary[i].length() % 3 == 2) {
                binary[i] = "0" + binary[i];
            }
            for (int j = 3; j <= binary[i].length(); j += 3) {
                String tmp = binary[i].substring(oldIndex, j);
                switch (tmp) {
                    case "000":resultTmp.append("0");break;
                    case "001":resultTmp.append("1");break;
                    case "010":resultTmp.append("2");break;
                    case "011":resultTmp.append("3");break;
                    case "100":resultTmp.append("4");break;
                    case "101":resultTmp.append("5");break;
                    case "110":resultTmp.append("6");break;
                    case "111":resultTmp.append("7");break;
                    default:break;
                }
                oldIndex = j;

            }

            if (resultTmp.charAt(0) == '0') {
                result[i] = resultTmp.substring(1, resultTmp.length());
            } else {
                result[i] = resultTmp.toString();
            }
            resultTmp = null;//置空,以便下一个字符串的转换
            resultTmp = new StringBuffer();

        }
        return result;
    }

    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        String[] num = new String[n];
        for (int i = 0; i < num.length; i++) {
            num[i] = sc.next();
        }
        sc.close();
        String[] tmp = toBinary(num);
        String[] result = toOctal(tmp);
        for (int i = 0; i < result.length; i++) {
            System.out.println(result[i]);
        }

    }
}

posted @ 2022-03-18 23:12  morning-start  阅读(46)  评论(0编辑  收藏  举报