蓝桥杯 基础练习 十六进制转八进制

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


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


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


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


样例输入
  2
  39
  123ABC


样例输出
  71
  4435274


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


分析:先将十六进制转换成二进制,再把二进制转换成八进制。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Scanner;
public class Main {
	public static void main(String[] args) throws IOException {
		BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
		int n = Integer.parseInt(in.readLine());
		String a[] = new String[n];
		for (int i = 0; i < n; i++) {
			a[i] = in.readLine();
		}

		for (int i = 0; i < n; i++) {
			char[] temp = a[i].toCharArray();
			StringBuffer s2 = new StringBuffer();
			int k = temp.length;
			for (int j = 0; j < k; j++) {
				switch (temp[j]) {
				case '0':
					s2.append("0000");
					break;
				case '1':
					s2.append("0001");
					break;
				case '2':
					s2.append("0010");
					break;
				case '3':
					s2.append("0011");
					break;
				case '4':
					s2.append("0100");
					break;
				case '5':
					s2.append("0101");
					break;
				case '6':
					s2.append("0110");
					break;
				case '7':
					s2.append("0111");
					break;
				case '8':
					s2.append("1000");
					break;
				case '9':
					s2.append("1001");
					break;
				case 'A':
					s2.append("1010");
					break;
				case 'B':
					s2.append("1011");
					break;
				case 'C':
					s2.append("1100");
					break;
				case 'D':
					s2.append("1101");
					break;
				case 'E':
					s2.append("1110");
					break;
				case 'F':
					s2.append("1111");
					break;
				}
			}
			StringBuffer s3 = new StringBuffer();
			int m = 0;
			if (4 * k % 3 == 1) {
				s3.append(s2.substring(0, 1));
				m += 1;
			} else if (4 * k % 3 == 2) {
				switch (s2.substring(0, 2)) {
				case "01":
					s3.append("1");
					break;
				case "10":
					s3.append("2");
					break;
				case "11":
					s3.append("3");
					break;
				default:
					break;
				}
				m += 2;
			}
			for (int j = m; j < 4 * k;) {
				switch (s2.substring(j, j + 3)) {
				case "000":
					s3.append("0");
					break;
				case "001":
					s3.append("1");
					break;
				case "010":
					s3.append("2");
					break;
				case "011":
					s3.append("3");
					break;
				case "100":
					s3.append("4");
					break;
				case "101":
					s3.append("5");
					break;
				case "110":
					s3.append("6");
					break;
				case "111":
					s3.append("7");
					break;
				}
				j += 3;
			}
			// delete 0
			// use delete(old is 0) or charAt

			if (s3.length() == 2 && s3.charAt(0) == '0') {// 0-->00-->delete 00-->notany
				System.out.println(s3.substring(1));
			} else {
				int q = 0;
				while (s3.charAt(q) == '0') {
					q++;
				}
				String s = s3.toString();
				System.out.println(s3.substring(q));
			}
		}
	}
}

注意:读取文件的方式和substring的用法、

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值