本文主要是介绍蓝桥杯试题--基础练习 十六进制转八进制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
资源限制
时间限制:1.0s
内存限制:512.0MB
问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2 39 123ABC样例输出
71 4435274
【提示】
先将十六进制数转换成某进制数,再由某进制数转换成八进制。
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();for(int cnt=0;cnt<n;cnt++){String str = sc.next();StringBuilder str2 = To_binary(str);To_Octal(str2);}}public static StringBuilder To_binary(String str){ //16进制转换为2进制StringBuilder str2 = new StringBuilder(); //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;default:break;}}return str2;}public static void To_Octal(StringBuilder str){ //转为8进制,转1位输出1位int len = str.length();int ans=0,s = 0;if(len % 3==1){ //最高位的补零模拟ans = str.charAt(0)-'0';s+=1;}else if(len % 3==2){ans = (str.charAt(0)-'0')*2 + (str.charAt(1)-'0');s+=2;}if(ans>0)System.out.print(ans);boolean flog = true;for(int i=s;i<str.length();i+=3){ans =(str.charAt(i)-'0')*4+ (str.charAt(i+1)-'0')*2 + (str.charAt(i+2)-'0');if(flog){if(ans==0){continue;}else{flog = false;}}System.out.print(ans);}System.out.println();}
}
这篇关于蓝桥杯试题--基础练习 十六进制转八进制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!