问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】
输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2
39
123ABC
样例输出
71
4435274
【提示】
先将十六进制数转换成某进制数,再由某进制数转换成八进制。
解题思路:需要创建两个方法先将16进制转换成2进制,然后再将转换的二进制转换为8进制,16转二即一位变四位,可以用switch case现,用stringbuilder的append方法。2转8即3位转一位,这里要注意首先将2进制的位数用3求余将多余的位数先转化为8进制输出,这里运用的是转化一位输出一位。方便操作。这里要注意如果转换的首位是0则不输出。
import java.util.Scanner;
public class ShiLiutoBa {
public static void main(String args[]) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
for(int i=0;i<n;i++) {
String str=sc.next();
StringBuilder str1=to_TWo(str);
to_Octumber(str1);
}
}
public static StringBuilder to_TWo(String str) {
StringBuilder str2=new StringBuilder();
for(int i=0;i<str.length();i++) {
char c=str.charAt(i);
switch(c) {
case'0':str2.append("0000");break;
case'1':str2.append("0001");break;
case'2':str2.append("0010");break;
case'3':str2.append("0011");break;
case'4':str2.append("0100");break;
case'5':str2.append("0101");break;
case'6':str2.append("0110");break;
case'7':str2.append("0111");break;
case'8':str2.append("1000");break;
case'9':str2.append("1001");break;
case'A':str2.append("1010");break;
case'B':str2.append("1011");break;
case'C':str2.append("1100");break;
case'D':str2.append("1101");break;
case'E':str2.append("1110");break;
case'F':str2.append("1111");break;
}
}
return str2;
}
public static void to_Octumber(StringBuilder str) {//计算一位输出一位
int str3=0,s=0;
int leng=str.length();
if(leng%3==1) { //3位为一个八进制,所以把多余直接计算。
str3=str.charAt(0)-'0';
s=1;
}else if(leng%3==2) {
str3=(str.charAt(0)-'0')*2+str.charAt(1)-'0';//注意这里的括号
s=2;
}
if(str3>0)
System.out.print(str3);//注意这里要判断首位0不输出
for(int i=s;i<leng-s;i+=3) {
str3=(str.charAt(i)-'0')*4+(str.charAt(i+1)-'0')*2+str.charAt(i+2)-'0';
if(str3>0)//注意这里要判断首位0不输出
System.out.print(str3);
}
System.out.println();
}
}