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

十六进制转换八进制

问题描述

  给定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.InputStreamReader;
import java.util.Arrays;
import java.util.Scanner;

public class  Main{
	public static void main(String[] args) throws Exception {
		BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
		int n = Integer.parseInt(buf.readLine());
		String str[] = new String[n];
		for(int i=0;i<n;i++)
			str[i] = buf.readLine();  //输入n个字符串
		for(int j=0;j<n;j++)
			transform2(str[j]);
	}
   //将十六进制转换为二进制
	private static void transform2(String s) {
		// TODO Auto-generated method stub
		StringBuffer st = new StringBuffer();
		char c[] = s.toCharArray();  //将字符串转换为字符数组
		for(int i=0;i<c.length;i++){
			switch(c[i]){
			case '0':
				st.append("0000");
				break;
			case '1':
				st.append("0001");
				break;
			case '2':
				st.append("0010");
				break;
			case '3':
				st.append("0011");
				break;
			case '4':
				st.append("0100");
				break;
			case '5':
				st.append("0101");
				break;
			case '6':
				st.append("0110");
				break;
			case '7':
				st.append("0111");
				break;
			case '8':
				st.append("1000");
				break;
			case '9':
				st.append("1001");
				break;
			case 'A':
				st.append("1010");
				break;
			case 'B':
				st.append("1011");
				break;
			case 'C':
				st.append("1100");
				break;
			case 'D':
				st.append("1101");
				break;
			case 'E':
				st.append("1110");
				break;
			case 'F':
				st.append("1111");
				break;
			}
		}
		transform8(st);
	}
  //将二进制转换为八进制
	private static void transform8(StringBuffer s) {
		// TODO Auto-generated method stub
		int i = s.length();
//		System.out.println(s);
//		System.out.println(i);
		//字符串的长度除以3谁的余数有0,1,2三种情况
		if(i%3==0){
			if(s.substring(0,3).equals("000"))
			    s.delete(0, 3);
		}
		if(i%3==1){
			if(s.substring(0, 1).equals("0"))
				s.delete(0, 1);
			else
				s.insert(0, "00");
		}
		if(i%3==2){
			if(s.substring(0, 2).equals("00"))
			    s.delete(0, 2);
			else
				s.insert(0, "0");
		}
		int n = s.length()/3;
		String s1[] = new String[n];
		StringBuffer sbf = new StringBuffer();
		for(int j=0;j<n;j++){
			s1[j] = s.substring(j*3,j*3+3);
			if(s1[j].equals("000"))
				sbf.append('0');
			if(s1[j].equals("001"))
				sbf.append('1');
			if(s1[j].equals("010"))
				sbf.append('2');
			if(s1[j].equals("011"))
				sbf.append('3');
			if(s1[j].equals("100"))
				sbf.append('4');
			if(s1[j].equals("101"))
				sbf.append('5');
			if(s1[j].equals("110"))
				sbf.append('6');
			if(s1[j].equals("111"))
				sbf.append('7');				
		}
		String s2 = sbf.toString();
		System.out.println(s2);
	}
}


知识总结:
Integer.parseInt(String s)是将是数字的字符串转成数字,注意他返回的是int型变量不具备方法和属性
Bufferedreader的用法要比inputstring复杂,它可以一次读取大量的数据,减少io的次数,提高效率
Stringbuffer类可以完成字符串的动态添加、插入和替换等操作
append方法,该方法的作用是追加内容到当前StringBuffer对象的末尾,类似于字符串的连接
char charAt(int index):在当前Stringbuffer对象中索引号为index的字符。第一个字符的索引为“0”
Stringbuffer delete(intstart,int end):删除当前Stringbuffer对象中索引号start开始,到end结束的子串
Stringbuffer insert(offset,int )方法:在当前Stringbuffer对象中插入一个元素,在索引号offset处插入相应的值
Stringbuffer substring(int start,int end):去当前Stringbuffer对象中,从start开始到结尾的子串
Stringbuffer toString():将当前Stringbuffer对象转换成String对象


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值