学习分享
例题
给定n个十六进制正整数,输出它们对应的八进制数。
介绍
十六进制转八进制首先需要将其转化为二进制,然后再转化为八进制这样计算可以加快计算的速度,减少代码量
接下来先介绍十六进制转八进制的方法
十六进制转八进制
private static String www(String add){
int add_length=add.length();
StringBuffer sbb=new StringBuffer();
for(int i=0;i<add_length;i++){
switch(add.charAt(i))
{
case '0':sbb.append("0000"); break;
case '1':sbb.append("0001"); break;
case '2':sbb.append("0010"); break;
case '3':sbb.append("0011"); break;
case '4':sbb.append("0100"); break;
case '5':sbb.append("0101"); break;
case '6':sbb.append("0110"); break;
case '7':sbb.append("0111"); break;
case '8':sbb.append("1000"); break;
case '9':sbb.append("1001"); break;
case 'A':sbb.append("1010"); break;
case 'B':sbb.append("1011"); break;
case 'C':sbb.append("1100"); break;
case 'D':sbb.append("1101"); break;
case 'E':sbb.append("1110"); break;
case 'F':sbb.append("1111"); break;
default:
break;
}
}
return sbb.toString();
}
用了StringBuffer 类里面的append方法,这个方法可以新建立一个数组来存放转化为二进制的数据,其中的toString方法可以将其中的数据转化为字符串类型
二进制转化为八进制
private static String toOctal(String strBinary) {
int len = strBinary.length();
int k;
StringBuffer sBuffer = new StringBuffer();
if (strBinary.substring(0, 3).equals("000")) {//看看前三位是不是0,是零就从第四位开始截取
k=3;
} else {
k=0;
}
for(int i=k;i<len-2;i+=3){
switch (strBinary.substring(i,i+3)){
case "000":sBuffer.append("0");break;
case "001":sBuffer.append("1");break;
case "010":sBuffer.append("2");break;
case "011":sBuffer.append("3");break;
case "100":sBuffer.append("4");break;
case "101":sBuffer.append("5");break;
case "110":sBuffer.append("6");break;
case "111":sBuffer.append("7");break;
default:
break;
}
}
return sBuffer.toString();
}
接下来是最终代码
import java.util.*;
public class Main{
public static void main(String args[]){
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
String[] a=new String[n];
for(int i=0;i<n;i++){
a[i]=sc.next();
}
sc.close();
for(int j=0;j<n;j++){
String d=www(a[j]);
int len=d.length();
if(len%3==1) d="00"+d;
if(len%3==2) d="0"+d;
String strOctal = toOctal(d);
System.out.println(strOctal);
}
}
private static String www(String add){
int add_length=add.length();
StringBuffer sbb=new StringBuffer();
for(int i=0;i<add_length;i++){
switch(add.charAt(i))
{
case '0':sbb.append("0000"); break;
case '1':sbb.append("0001"); break;
case '2':sbb.append("0010"); break;
case '3':sbb.append("0011"); break;
case '4':sbb.append("0100"); break;
case '5':sbb.append("0101"); break;
case '6':sbb.append("0110"); break;
case '7':sbb.append("0111"); break;
case '8':sbb.append("1000"); break;
case '9':sbb.append("1001"); break;
case 'A':sbb.append("1010"); break;
case 'B':sbb.append("1011"); break;
case 'C':sbb.append("1100"); break;
case 'D':sbb.append("1101"); break;
case 'E':sbb.append("1110"); break;
case 'F':sbb.append("1111"); break;
default:
break;
}
}
return sbb.toString();
}
private static String toOctal(String strBinary) {
int len = strBinary.length();
int k;
StringBuffer sBuffer = new StringBuffer();
if (strBinary.substring(0, 3).equals("000")) {//看看前三位是不是0,是零就从第四位开始截取
k=3;
} else {
k=0;
}
for(int i=k;i<len-2;i+=3){
switch (strBinary.substring(i,i+3)){
case "000":sBuffer.append("0");break;
case "001":sBuffer.append("1");break;
case "010":sBuffer.append("2");break;
case "011":sBuffer.append("3");break;
case "100":sBuffer.append("4");break;
case "101":sBuffer.append("5");break;
case "110":sBuffer.append("6");break;
case "111":sBuffer.append("7");break;
default:
break;
}
}
return sBuffer.toString();
}
}
介绍完毕。