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]);
}
}
}