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

来源:互联网 发布:苹果电脑安装淘宝助理 编辑:程序博客网 时间:2024/05/20 14:44

十六进制转换八进制

问题描述

  给定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 stubStringBuffer 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 stubint 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);elses.insert(0, "00");}if(i%3==2){if(s.substring(0, 2).equals("00"))    s.delete(0, 2);elses.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 0
原创粉丝点击